HardwareVideoEncoder.smali

.class Lorg/webrtc/ali/HardwareVideoEncoder;
.super Ljava/lang/Object;
.source "HardwareVideoEncoder.java"

# interfaces
.implements Lorg/webrtc/ali/VideoEncoder;


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;
    }
.end annotation


# static fields
.field private static final DEQUEUE_OUTPUT_BUFFER_TIMEOUT_US:I

.field private static final KEY_BITRATE_MODE:Ljava/lang/String; = "bitrate-mode"

.field private static final MAX_ENCODER_Q_SIZE:I

.field private static final MAX_VIDEO_FRAMERATE:I

.field private static final MEDIA_CODEC_RELEASE_TIMEOUT_MS:I

.field private static final TAG:Ljava/lang/String; = "HardwareVideoEncoder"

.field private static final VIDEO_ControlRateConstant:I


# instance fields
.field private adjustedBitrate:I

.field private final bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;

.field private callback:Lorg/webrtc/ali/VideoEncoder$Callback;

.field private codec:Landroid/media/MediaCodec;

.field private final codecName:Ljava/lang/String;

.field private final codecType:Lorg/webrtc/ali/VideoCodecType;

.field private final colorFormat:I

.field private configBuffer:Ljava/nio/ByteBuffer;

.field private final forcedKeyFrameMs:J

.field private height:I

.field private final inputColorFormat:Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;

.field private final keyFrameIntervalSec:I

.field private lastKeyFrameMs:J

.field private final outputBuilders:Ljava/util/Deque;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Deque<",
            "Lorg/webrtc/ali/EncodedImage$Builder;",
            ">;"
        }
    .end annotation
.end field

.field private outputThread:Ljava/lang/Thread;

.field private volatile running:Z

.field private volatile shutdownException:Ljava/lang/Exception;

.field private width:I


# direct methods
.method static constructor <clinit>()V
    .registers 1

    const v0, 0x193cf

    invoke-static {v0}, Lnp/NPFog;->d(I)I

    move-result v0

    sput v0, Lorg/webrtc/ali/HardwareVideoEncoder;->DEQUEUE_OUTPUT_BUFFER_TIMEOUT_US:I

    const v0, 0x156d

    invoke-static {v0}, Lnp/NPFog;->d(I)I

    move-result v0

    sput v0, Lorg/webrtc/ali/HardwareVideoEncoder;->MAX_ENCODER_Q_SIZE:I

    const v0, 0x1571

    invoke-static {v0}, Lnp/NPFog;->d(I)I

    move-result v0

    sput v0, Lorg/webrtc/ali/HardwareVideoEncoder;->MAX_VIDEO_FRAMERATE:I

    const v0, 0x6e7

    invoke-static {v0}, Lnp/NPFog;->d(I)I

    move-result v0

    sput v0, Lorg/webrtc/ali/HardwareVideoEncoder;->MEDIA_CODEC_RELEASE_TIMEOUT_MS:I

    const v0, 0x156d

    invoke-static {v0}, Lnp/NPFog;->d(I)I

    move-result v0

    sput v0, Lorg/webrtc/ali/HardwareVideoEncoder;->VIDEO_ControlRateConstant:I

    return-void
.end method

.method public constructor <init>(Ljava/lang/String;Lorg/webrtc/ali/VideoCodecType;IIILorg/webrtc/ali/BitrateAdjuster;)V
    .registers 9
    .param p1, "codecName"    # Ljava/lang/String;
    .param p2, "codecType"    # Lorg/webrtc/ali/VideoCodecType;
    .param p3, "colorFormat"    # I
    .param p4, "keyFrameIntervalSec"    # I
    .param p5, "forceKeyFrameIntervalMs"    # I
    .param p6, "bitrateAdjuster"    # Lorg/webrtc/ali/BitrateAdjuster;

    .line 100
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 71
    const/4 v0, 0x0

    iput-boolean v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->running:Z

    .line 74
    const/4 v0, 0x0

    iput-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->shutdownException:Ljava/lang/Exception;

    .line 83
    iput-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->configBuffer:Ljava/nio/ByteBuffer;

    .line 101
    iput-object p1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecName:Ljava/lang/String;

    .line 102
    iput-object p2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecType:Lorg/webrtc/ali/VideoCodecType;

    .line 103
    iput p3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->colorFormat:I

    .line 104
    invoke-static {p3}, Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;->valueOf(I)Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;

    move-result-object v0

    iput-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->inputColorFormat:Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;

    .line 105
    iput p4, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->keyFrameIntervalSec:I

    .line 106
    int-to-long v0, p5

    iput-wide v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->forcedKeyFrameMs:J

    .line 107
    iput-object p6, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;

    .line 108
    new-instance v0, Ljava/util/concurrent/LinkedBlockingDeque;

    invoke-direct {v0}, Ljava/util/concurrent/LinkedBlockingDeque;-><init>()V

    iput-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;

    .line 109
    return-void
.end method

.method static synthetic access$000(Lorg/webrtc/ali/HardwareVideoEncoder;)Z
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/HardwareVideoEncoder;

    .line 29
    iget-boolean v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->running:Z

    return v0
.end method

.method static synthetic access$100(Lorg/webrtc/ali/HardwareVideoEncoder;)V
    .registers 1
    .param p0, "x0"    # Lorg/webrtc/ali/HardwareVideoEncoder;

    .line 29
    invoke-direct {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->deliverEncodedImage()V

    return-void
.end method

.method static synthetic access$200(Lorg/webrtc/ali/HardwareVideoEncoder;)V
    .registers 1
    .param p0, "x0"    # Lorg/webrtc/ali/HardwareVideoEncoder;

    .line 29
    invoke-direct {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->releaseCodecOnOutputThread()V

    return-void
.end method

.method private createOutputThread()Ljava/lang/Thread;
    .registers 2

    .line 323
    new-instance v0, Lorg/webrtc/ali/HardwareVideoEncoder$1;

    invoke-direct {v0, p0}, Lorg/webrtc/ali/HardwareVideoEncoder$1;-><init>(Lorg/webrtc/ali/HardwareVideoEncoder;)V

    return-object v0
.end method

.method private deliverEncodedImage()V
    .registers 13

    .line 336
    const-string v0, "HardwareVideoEncoder"

    :try_start_2
    new-instance v1, Landroid/media/MediaCodec$BufferInfo;

    invoke-direct {v1}, Landroid/media/MediaCodec$BufferInfo;-><init>()V

    .line 337
    .local v1, "info":Landroid/media/MediaCodec$BufferInfo;
    iget-object v2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    const-wide/32 v3, 0x186a0

    invoke-virtual {v2, v1, v3, v4}, Landroid/media/MediaCodec;->dequeueOutputBuffer(Landroid/media/MediaCodec$BufferInfo;J)I

    move-result v2

    .line 338
    .local v2, "index":I
    if-gez v2, :cond_13

    .line 339
    return-void

    .line 342
    :cond_13
    iget-object v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    invoke-virtual {v3}, Landroid/media/MediaCodec;->getOutputBuffers()[Ljava/nio/ByteBuffer;

    move-result-object v3

    aget-object v3, v3, v2

    .line 343
    .local v3, "codecOutputBuffer":Ljava/nio/ByteBuffer;
    iget v4, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I

    invoke-virtual {v3, v4}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;

    .line 344
    iget v4, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I

    iget v5, v1, Landroid/media/MediaCodec$BufferInfo;->size:I

    add-int/2addr v4, v5

    invoke-virtual {v3, v4}, Ljava/nio/ByteBuffer;->limit(I)Ljava/nio/Buffer;

    .line 346
    iget v4, v1, Landroid/media/MediaCodec$BufferInfo;->flags:I

    and-int/lit8 v4, v4, 0x2

    const/4 v5, 0x0

    if-eqz v4, :cond_5c

    .line 347
    new-instance v4, Ljava/lang/StringBuilder;

    invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V

    const-string v6, "Config frame generated. Offset: "

    invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget v6, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I

    invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v6, ". Size: "

    invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget v6, v1, Landroid/media/MediaCodec$BufferInfo;->size:I

    invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v4

    invoke-static {v0, v4}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 348
    iget v4, v1, Landroid/media/MediaCodec$BufferInfo;->size:I

    invoke-static {v4}, Ljava/nio/ByteBuffer;->allocateDirect(I)Ljava/nio/ByteBuffer;

    move-result-object v4

    iput-object v4, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->configBuffer:Ljava/nio/ByteBuffer;

    .line 349
    invoke-virtual {v4, v3}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;

    goto/16 :goto_fc

    .line 351
    :cond_5c
    iget-object v4, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;

    iget v6, v1, Landroid/media/MediaCodec$BufferInfo;->size:I

    invoke-interface {v4, v6}, Lorg/webrtc/ali/BitrateAdjuster;->reportEncodedFrame(I)V

    .line 352
    iget v4, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->adjustedBitrate:I

    iget-object v6, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;

    invoke-interface {v6}, Lorg/webrtc/ali/BitrateAdjuster;->getAdjustedBitrateBps()I

    move-result v6

    if-eq v4, v6, :cond_70

    .line 353
    invoke-direct {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->updateBitrate()Lorg/webrtc/ali/VideoCodecStatus;

    .line 357
    :cond_70
    iget v4, v1, Landroid/media/MediaCodec$BufferInfo;->flags:I

    const/4 v6, 0x1

    and-int/2addr v4, v6

    if-eqz v4, :cond_77

    goto :goto_78

    :cond_77
    const/4 v6, 0x0

    :goto_78
    move v4, v6

    .line 358
    .local v4, "isKeyFrame":Z
    if-eqz v4, :cond_c7

    iget-object v6, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecType:Lorg/webrtc/ali/VideoCodecType;

    sget-object v7, Lorg/webrtc/ali/VideoCodecType;->H264:Lorg/webrtc/ali/VideoCodecType;

    if-ne v6, v7, :cond_c7

    .line 359
    new-instance v6, Ljava/lang/StringBuilder;

    invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V

    const-string v7, "Prepending config frame of size "

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v7, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->configBuffer:Ljava/nio/ByteBuffer;

    .line 360
    invoke-virtual {v7}, Ljava/nio/ByteBuffer;->capacity()I

    move-result v7

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v7, " to output buffer with offset "

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget v7, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v7, ", size "

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget v7, v1, Landroid/media/MediaCodec$BufferInfo;->size:I

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v6

    .line 359
    invoke-static {v0, v6}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 363
    iget v6, v1, Landroid/media/MediaCodec$BufferInfo;->size:I

    iget-object v7, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->configBuffer:Ljava/nio/ByteBuffer;

    invoke-virtual {v7}, Ljava/nio/ByteBuffer;->capacity()I

    move-result v7

    add-int/2addr v6, v7

    invoke-static {v6}, Ljava/nio/ByteBuffer;->allocateDirect(I)Ljava/nio/ByteBuffer;

    move-result-object v6

    .line 364
    .local v6, "frameBuffer":Ljava/nio/ByteBuffer;
    iget-object v7, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->configBuffer:Ljava/nio/ByteBuffer;

    invoke-virtual {v7}, Ljava/nio/ByteBuffer;->rewind()Ljava/nio/Buffer;

    .line 365
    iget-object v7, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->configBuffer:Ljava/nio/ByteBuffer;

    invoke-virtual {v6, v7}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;

    goto :goto_cd

    .line 367
    .end local v6    # "frameBuffer":Ljava/nio/ByteBuffer;
    :cond_c7
    iget v6, v1, Landroid/media/MediaCodec$BufferInfo;->size:I

    invoke-static {v6}, Ljava/nio/ByteBuffer;->allocateDirect(I)Ljava/nio/ByteBuffer;

    move-result-object v6

    .line 369
    .restart local v6    # "frameBuffer":Ljava/nio/ByteBuffer;
    :goto_cd
    invoke-virtual {v6, v3}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;

    .line 370
    invoke-virtual {v6}, Ljava/nio/ByteBuffer;->rewind()Ljava/nio/Buffer;

    .line 372
    sget-object v7, Lorg/webrtc/ali/EncodedImage$FrameType;->VideoFrameDelta:Lorg/webrtc/ali/EncodedImage$FrameType;

    .line 373
    .local v7, "frameType":Lorg/webrtc/ali/EncodedImage$FrameType;
    if-eqz v4, :cond_df

    .line 374
    const-string v8, "Sync frame generated"

    invoke-static {v0, v8}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 375
    sget-object v8, Lorg/webrtc/ali/EncodedImage$FrameType;->VideoFrameKey:Lorg/webrtc/ali/EncodedImage$FrameType;

    move-object v7, v8

    .line 377
    :cond_df
    iget-object v8, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;

    invoke-interface {v8}, Ljava/util/Deque;->poll()Ljava/lang/Object;

    move-result-object v8

    check-cast v8, Lorg/webrtc/ali/EncodedImage$Builder;

    .line 378
    .local v8, "builder":Lorg/webrtc/ali/EncodedImage$Builder;
    invoke-virtual {v8, v6}, Lorg/webrtc/ali/EncodedImage$Builder;->setBuffer(Ljava/nio/ByteBuffer;)Lorg/webrtc/ali/EncodedImage$Builder;

    move-result-object v9

    invoke-virtual {v9, v7}, Lorg/webrtc/ali/EncodedImage$Builder;->setFrameType(Lorg/webrtc/ali/EncodedImage$FrameType;)Lorg/webrtc/ali/EncodedImage$Builder;

    .line 380
    iget-object v9, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->callback:Lorg/webrtc/ali/VideoEncoder$Callback;

    invoke-virtual {v8}, Lorg/webrtc/ali/EncodedImage$Builder;->createEncodedImage()Lorg/webrtc/ali/EncodedImage;

    move-result-object v10

    new-instance v11, Lorg/webrtc/ali/VideoEncoder$CodecSpecificInfo;

    invoke-direct {v11}, Lorg/webrtc/ali/VideoEncoder$CodecSpecificInfo;-><init>()V

    invoke-interface {v9, v10, v11}, Lorg/webrtc/ali/VideoEncoder$Callback;->onEncodedFrame(Lorg/webrtc/ali/EncodedImage;Lorg/webrtc/ali/VideoEncoder$CodecSpecificInfo;)V

    .line 382
    .end local v4    # "isKeyFrame":Z
    .end local v6    # "frameBuffer":Ljava/nio/ByteBuffer;
    .end local v7    # "frameType":Lorg/webrtc/ali/EncodedImage$FrameType;
    .end local v8    # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
    :goto_fc
    iget-object v4, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    invoke-virtual {v4, v2, v5}, Landroid/media/MediaCodec;->releaseOutputBuffer(IZ)V
    :try_end_101
    .catch Ljava/lang/IllegalStateException; {:try_start_2 .. :try_end_101} :catch_102

    .line 385
    .end local v1    # "info":Landroid/media/MediaCodec$BufferInfo;
    .end local v2    # "index":I
    .end local v3    # "codecOutputBuffer":Ljava/nio/ByteBuffer;
    goto :goto_108

    .line 383
    :catch_102
    move-exception v1

    .line 384
    .local v1, "e":Ljava/lang/IllegalStateException;
    const-string v2, "deliverOutput failed"

    invoke-static {v0, v2, v1}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 386
    .end local v1    # "e":Ljava/lang/IllegalStateException;
    :goto_108
    return-void
.end method

.method private initEncodeInternal(IIIILorg/webrtc/ali/VideoEncoder$Callback;)Lorg/webrtc/ali/VideoCodecStatus;
    .registers 11
    .param p1, "width"    # I
    .param p2, "height"    # I
    .param p3, "bitrateKbps"    # I
    .param p4, "fps"    # I
    .param p5, "callback"    # Lorg/webrtc/ali/VideoEncoder$Callback;

    .line 119
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "initEncode: "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v1, " x "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v1, ". @ "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0, p3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v1, "kbps. Fps: "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0, p4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    const-string v1, "HardwareVideoEncoder"

    invoke-static {v1, v0}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 121
    iput p1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->width:I

    .line 122
    iput p2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->height:I

    .line 123
    if-eqz p3, :cond_3d

    if-eqz p4, :cond_3d

    .line 124
    iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;

    mul-int/lit16 v2, p3, 0x3e8

    invoke-interface {v0, v2, p4}, Lorg/webrtc/ali/BitrateAdjuster;->setTargets(II)V

    .line 126
    :cond_3d
    iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;

    invoke-interface {v0}, Lorg/webrtc/ali/BitrateAdjuster;->getAdjustedBitrateBps()I

    move-result v0

    iput v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->adjustedBitrate:I

    .line 128
    iput-object p5, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->callback:Lorg/webrtc/ali/VideoEncoder$Callback;

    .line 130
    const-wide/16 v2, -0x1

    iput-wide v2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->lastKeyFrameMs:J

    .line 133
    :try_start_4b
    iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecName:Ljava/lang/String;

    invoke-static {v0}, Landroid/media/MediaCodec;->createByCodecName(Ljava/lang/String;)Landroid/media/MediaCodec;

    move-result-object v0

    iput-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
    :try_end_53
    .catch Ljava/io/IOException; {:try_start_4b .. :try_end_53} :catch_c1
    .catch Ljava/lang/IllegalArgumentException; {:try_start_4b .. :try_end_53} :catch_bf

    .line 137
    nop

    .line 139
    :try_start_54
    iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecType:Lorg/webrtc/ali/VideoCodecType;

    invoke-virtual {v0}, Lorg/webrtc/ali/VideoCodecType;->mimeType()Ljava/lang/String;

    move-result-object v0

    invoke-static {v0, p1, p2}, Landroid/media/MediaFormat;->createVideoFormat(Ljava/lang/String;II)Landroid/media/MediaFormat;

    move-result-object v0

    .line 140
    .local v0, "format":Landroid/media/MediaFormat;
    const-string v2, "bitrate"

    iget v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->adjustedBitrate:I

    invoke-virtual {v0, v2, v3}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V

    .line 141
    const-string v2, "bitrate-mode"

    const/4 v3, 0x2

    invoke-virtual {v0, v2, v3}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V

    .line 142
    const-string v2, "color-format"

    iget v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->colorFormat:I

    invoke-virtual {v0, v2, v3}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V

    .line 143
    const-string v2, "frame-rate"

    iget-object v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;

    invoke-interface {v3}, Lorg/webrtc/ali/BitrateAdjuster;->getAdjustedFramerate()I

    move-result v3

    invoke-virtual {v0, v2, v3}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V

    .line 144
    const-string v2, "i-frame-interval"

    iget v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->keyFrameIntervalSec:I

    invoke-virtual {v0, v2, v3}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V

    .line 145
    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    const-string v3, "Format: "

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v2

    invoke-static {v1, v2}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 146
    iget-object v2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    const/4 v3, 0x1

    const/4 v4, 0x0

    invoke-virtual {v2, v0, v4, v4, v3}, Landroid/media/MediaCodec;->configure(Landroid/media/MediaFormat;Landroid/view/Surface;Landroid/media/MediaCrypto;I)V

    .line 147
    iget-object v2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    invoke-virtual {v2}, Landroid/media/MediaCodec;->start()V
    :try_end_a4
    .catch Ljava/lang/IllegalStateException; {:try_start_54 .. :try_end_a4} :catch_b3

    .line 152
    .end local v0    # "format":Landroid/media/MediaFormat;
    nop

    .line 154
    iput-boolean v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->running:Z

    .line 155
    invoke-direct {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->createOutputThread()Ljava/lang/Thread;

    move-result-object v0

    iput-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputThread:Ljava/lang/Thread;

    .line 156
    invoke-virtual {v0}, Ljava/lang/Thread;->start()V

    .line 158
    sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;

    return-object v0

    .line 148
    :catch_b3
    move-exception v0

    .line 149
    .local v0, "e":Ljava/lang/IllegalStateException;
    const-string v2, "initEncode failed"

    invoke-static {v1, v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 150
    invoke-virtual {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->release()Lorg/webrtc/ali/VideoCodecStatus;

    .line 151
    sget-object v1, Lorg/webrtc/ali/VideoCodecStatus;->ERROR:Lorg/webrtc/ali/VideoCodecStatus;

    return-object v1

    .line 134
    .end local v0    # "e":Ljava/lang/IllegalStateException;
    :catch_bf
    move-exception v0

    goto :goto_c2

    :catch_c1
    move-exception v0

    .line 135
    .local v0, "e":Ljava/lang/Exception;
    :goto_c2
    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    const-string v3, "Cannot create media encoder "

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecName:Ljava/lang/String;

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v2

    invoke-static {v1, v2}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 136
    sget-object v1, Lorg/webrtc/ali/VideoCodecStatus;->ERROR:Lorg/webrtc/ali/VideoCodecStatus;

    return-object v1
.end method

.method private releaseCodecOnOutputThread()V
    .registers 4

    .line 389
    const-string v0, "HardwareVideoEncoder"

    const-string v1, "Releasing MediaCodec on output thread"

    invoke-static {v0, v1}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 391
    :try_start_7
    iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    invoke-virtual {v1}, Landroid/media/MediaCodec;->stop()V
    :try_end_c
    .catch Ljava/lang/Exception; {:try_start_7 .. :try_end_c} :catch_d

    .line 394
    goto :goto_13

    .line 392
    :catch_d
    move-exception v1

    .line 393
    .local v1, "e":Ljava/lang/Exception;
    const-string v2, "Media encoder stop failed"

    invoke-static {v0, v2, v1}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 396
    .end local v1    # "e":Ljava/lang/Exception;
    :goto_13
    :try_start_13
    iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    invoke-virtual {v1}, Landroid/media/MediaCodec;->release()V
    :try_end_18
    .catch Ljava/lang/Exception; {:try_start_13 .. :try_end_18} :catch_19

    .line 401
    goto :goto_21

    .line 397
    :catch_19
    move-exception v1

    .line 398
    .restart local v1    # "e":Ljava/lang/Exception;
    const-string v2, "Media encoder release failed"

    invoke-static {v0, v2, v1}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 400
    iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->shutdownException:Ljava/lang/Exception;

    .line 402
    .end local v1    # "e":Ljava/lang/Exception;
    :goto_21
    const-string v1, "Release on output thread done"

    invoke-static {v0, v1}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 403
    return-void
.end method

.method private requestKeyFrame(J)V
    .registers 6
    .param p1, "presentationTimestampMs"    # J

    .line 312
    :try_start_0
    new-instance v0, Landroid/os/Bundle;

    invoke-direct {v0}, Landroid/os/Bundle;-><init>()V

    .line 313
    .local v0, "b":Landroid/os/Bundle;
    const-string v1, "request-sync"

    const/4 v2, 0x0

    invoke-virtual {v0, v1, v2}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V

    .line 314
    iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    invoke-virtual {v1, v0}, Landroid/media/MediaCodec;->setParameters(Landroid/os/Bundle;)V
    :try_end_10
    .catch Ljava/lang/IllegalStateException; {:try_start_0 .. :try_end_10} :catch_14

    .line 318
    .end local v0    # "b":Landroid/os/Bundle;
    nop

    .line 319
    iput-wide p1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->lastKeyFrameMs:J

    .line 320
    return-void

    .line 315
    :catch_14
    move-exception v0

    .line 316
    .local v0, "e":Ljava/lang/IllegalStateException;
    const-string v1, "HardwareVideoEncoder"

    const-string v2, "requestKeyFrame failed"

    invoke-static {v1, v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 317
    return-void
.end method

.method private resetCodec(II)Lorg/webrtc/ali/VideoCodecStatus;
    .registers 11
    .param p1, "newWidth"    # I
    .param p2, "newHeight"    # I

    .line 294
    invoke-virtual {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->release()Lorg/webrtc/ali/VideoCodecStatus;

    move-result-object v0

    .line 295
    .local v0, "status":Lorg/webrtc/ali/VideoCodecStatus;
    sget-object v1, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;

    if-eq v0, v1, :cond_9

    .line 296
    return-object v0

    .line 299
    :cond_9
    const/4 v5, 0x0

    const/4 v6, 0x0

    iget-object v7, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->callback:Lorg/webrtc/ali/VideoEncoder$Callback;

    move-object v2, p0

    move v3, p1

    move v4, p2

    invoke-direct/range {v2 .. v7}, Lorg/webrtc/ali/HardwareVideoEncoder;->initEncodeInternal(IIIILorg/webrtc/ali/VideoEncoder$Callback;)Lorg/webrtc/ali/VideoCodecStatus;

    move-result-object v1

    return-object v1
.end method

.method private shouldForceKeyFrame(J)Z
    .registers 8
    .param p1, "presentationTimestampMs"    # J

    .line 303
    iget-wide v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->forcedKeyFrameMs:J

    const-wide/16 v2, 0x0

    cmp-long v4, v0, v2

    if-lez v4, :cond_11

    iget-wide v2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->lastKeyFrameMs:J

    add-long/2addr v2, v0

    cmp-long v0, p1, v2

    if-lez v0, :cond_11

    const/4 v0, 0x1

    goto :goto_12

    :cond_11
    const/4 v0, 0x0

    :goto_12
    return v0
.end method

.method private updateBitrate()Lorg/webrtc/ali/VideoCodecStatus;
    .registers 4

    .line 406
    iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;

    invoke-interface {v0}, Lorg/webrtc/ali/BitrateAdjuster;->getAdjustedBitrateBps()I

    move-result v0

    iput v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->adjustedBitrate:I

    .line 408
    :try_start_8
    new-instance v0, Landroid/os/Bundle;

    invoke-direct {v0}, Landroid/os/Bundle;-><init>()V

    .line 409
    .local v0, "params":Landroid/os/Bundle;
    const-string v1, "video-bitrate"

    iget v2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->adjustedBitrate:I

    invoke-virtual {v0, v1, v2}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V

    .line 410
    iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    invoke-virtual {v1, v0}, Landroid/media/MediaCodec;->setParameters(Landroid/os/Bundle;)V

    .line 411
    sget-object v1, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;
    :try_end_1b
    .catch Ljava/lang/IllegalStateException; {:try_start_8 .. :try_end_1b} :catch_1c

    return-object v1

    .line 412
    .end local v0    # "params":Landroid/os/Bundle;
    :catch_1c
    move-exception v0

    .line 413
    .local v0, "e":Ljava/lang/IllegalStateException;
    const-string v1, "HardwareVideoEncoder"

    const-string v2, "updateBitrate failed"

    invoke-static {v1, v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 414
    sget-object v1, Lorg/webrtc/ali/VideoCodecStatus;->ERROR:Lorg/webrtc/ali/VideoCodecStatus;

    return-object v1
.end method


# virtual methods
.method public encode(Lorg/webrtc/ali/VideoFrame;Lorg/webrtc/ali/VideoEncoder$EncodeInfo;)Lorg/webrtc/ali/VideoCodecStatus;
    .registers 26
    .param p1, "videoFrame"    # Lorg/webrtc/ali/VideoFrame;
    .param p2, "encodeInfo"    # Lorg/webrtc/ali/VideoEncoder$EncodeInfo;

    .line 185
    move-object/from16 v1, p0

    const-string v2, "HardwareVideoEncoder"

    iget-object v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    if-nez v0, :cond_b

    .line 186
    sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->UNINITIALIZED:Lorg/webrtc/ali/VideoCodecStatus;

    return-object v0

    .line 190
    :cond_b
    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getWidth()I

    move-result v3

    .line 191
    .local v3, "frameWidth":I
    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getHeight()I

    move-result v4

    .line 192
    .local v4, "frameHeight":I
    iget v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->width:I

    if-ne v3, v0, :cond_1b

    iget v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->height:I

    if-eq v4, v0, :cond_24

    .line 193
    :cond_1b
    invoke-direct {v1, v3, v4}, Lorg/webrtc/ali/HardwareVideoEncoder;->resetCodec(II)Lorg/webrtc/ali/VideoCodecStatus;

    move-result-object v0

    .line 194
    .local v0, "status":Lorg/webrtc/ali/VideoCodecStatus;
    sget-object v5, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;

    if-eq v0, v5, :cond_24

    .line 195
    return-object v0

    .line 202
    .end local v0    # "status":Lorg/webrtc/ali/VideoCodecStatus;
    :cond_24
    :try_start_24
    iget-object v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    const-wide/16 v5, 0x0

    invoke-virtual {v0, v5, v6}, Landroid/media/MediaCodec;->dequeueInputBuffer(J)I

    move-result v0
    :try_end_2c
    .catch Ljava/lang/IllegalStateException; {:try_start_24 .. :try_end_2c} :catch_106

    move v12, v0

    .line 206
    .local v12, "index":I
    nop

    .line 208
    const/4 v0, -0x1

    if-ne v12, v0, :cond_39

    .line 210
    const-string v0, "Dropped frame, no input buffers available"

    invoke-static {v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 211
    sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;

    return-object v0

    .line 213
    :cond_39
    iget-object v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;

    invoke-interface {v0}, Ljava/util/Deque;->size()I

    move-result v0

    const/4 v5, 0x2

    if-le v0, v5, :cond_4a

    .line 215
    const-string v0, "Dropped frame, encoder queue full"

    invoke-static {v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 216
    sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;

    return-object v0

    .line 222
    :cond_4a
    :try_start_4a
    iget-object v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    invoke-virtual {v0}, Landroid/media/MediaCodec;->getInputBuffers()[Ljava/nio/ByteBuffer;

    move-result-object v0

    aget-object v0, v0, v12
    :try_end_52
    .catch Ljava/lang/IllegalStateException; {:try_start_4a .. :try_end_52} :catch_fb

    move-object v13, v0

    .line 226
    .local v13, "buffer":Ljava/nio/ByteBuffer;
    nop

    .line 227
    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getBuffer()Lorg/webrtc/ali/VideoFrame$Buffer;

    move-result-object v0

    invoke-interface {v0}, Lorg/webrtc/ali/VideoFrame$Buffer;->toI420()Lorg/webrtc/ali/VideoFrame$I420Buffer;

    move-result-object v14

    .line 228
    .local v14, "i420":Lorg/webrtc/ali/VideoFrame$I420Buffer;
    iget-object v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->inputColorFormat:Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;

    invoke-virtual {v0, v13, v14}, Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;->fillBufferFromI420(Ljava/nio/ByteBuffer;Lorg/webrtc/ali/VideoFrame$I420Buffer;)V

    .line 230
    const/4 v0, 0x0

    .line 231
    .local v0, "requestedKeyFrame":Z
    move-object/from16 v15, p2

    iget-object v6, v15, Lorg/webrtc/ali/VideoEncoder$EncodeInfo;->frameTypes:[Lorg/webrtc/ali/EncodedImage$FrameType;

    array-length v7, v6

    const/4 v8, 0x0

    move/from16 v16, v0

    .end local v0    # "requestedKeyFrame":Z
    .local v16, "requestedKeyFrame":Z
    :goto_6a
    if-ge v8, v7, :cond_78

    aget-object v0, v6, v8

    .line 232
    .local v0, "frameType":Lorg/webrtc/ali/EncodedImage$FrameType;
    sget-object v9, Lorg/webrtc/ali/EncodedImage$FrameType;->VideoFrameKey:Lorg/webrtc/ali/EncodedImage$FrameType;

    if-ne v0, v9, :cond_75

    .line 233
    const/4 v9, 0x1

    move/from16 v16, v9

    .line 231
    .end local v0    # "frameType":Lorg/webrtc/ali/EncodedImage$FrameType;
    :cond_75
    add-int/lit8 v8, v8, 0x1

    goto :goto_6a

    .line 238
    :cond_78
    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getTimestampNs()J

    move-result-wide v6

    const-wide/16 v8, 0x1f4

    add-long/2addr v6, v8

    const-wide/16 v10, 0x3e8

    div-long v17, v6, v10

    .line 239
    .local v17, "presentationTimestampUs":J
    add-long v8, v17, v8

    div-long v9, v8, v10

    .line 240
    .local v9, "presentationTimestampMs":J
    if-nez v16, :cond_8f

    invoke-direct {v1, v9, v10}, Lorg/webrtc/ali/HardwareVideoEncoder;->shouldForceKeyFrame(J)Z

    move-result v0

    if-eqz v0, :cond_92

    .line 241
    :cond_8f
    invoke-direct {v1, v9, v10}, Lorg/webrtc/ali/HardwareVideoEncoder;->requestKeyFrame(J)V

    .line 246
    :cond_92
    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getBuffer()Lorg/webrtc/ali/VideoFrame$Buffer;

    move-result-object v0

    invoke-interface {v0}, Lorg/webrtc/ali/VideoFrame$Buffer;->getHeight()I

    move-result v0

    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getBuffer()Lorg/webrtc/ali/VideoFrame$Buffer;

    move-result-object v6

    invoke-interface {v6}, Lorg/webrtc/ali/VideoFrame$Buffer;->getWidth()I

    move-result v6

    mul-int v0, v0, v6

    mul-int/lit8 v0, v0, 0x3

    div-int/lit8 v19, v0, 0x2

    .line 247
    .local v19, "bufferSize":I
    invoke-static {}, Lorg/webrtc/ali/EncodedImage;->builder()Lorg/webrtc/ali/EncodedImage$Builder;

    move-result-object v0

    .line 248
    invoke-virtual {v0, v9, v10}, Lorg/webrtc/ali/EncodedImage$Builder;->setCaptureTimeMs(J)Lorg/webrtc/ali/EncodedImage$Builder;

    move-result-object v0

    .line 249
    const/4 v5, 0x1

    invoke-virtual {v0, v5}, Lorg/webrtc/ali/EncodedImage$Builder;->setCompleteFrame(Z)Lorg/webrtc/ali/EncodedImage$Builder;

    move-result-object v0

    .line 250
    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getWidth()I

    move-result v5

    invoke-virtual {v0, v5}, Lorg/webrtc/ali/EncodedImage$Builder;->setEncodedWidth(I)Lorg/webrtc/ali/EncodedImage$Builder;

    move-result-object v0

    .line 251
    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getHeight()I

    move-result v5

    invoke-virtual {v0, v5}, Lorg/webrtc/ali/EncodedImage$Builder;->setEncodedHeight(I)Lorg/webrtc/ali/EncodedImage$Builder;

    move-result-object v0

    .line 252
    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getRotation()I

    move-result v5

    invoke-virtual {v0, v5}, Lorg/webrtc/ali/EncodedImage$Builder;->setRotation(I)Lorg/webrtc/ali/EncodedImage$Builder;

    move-result-object v11

    .line 253
    .local v11, "builder":Lorg/webrtc/ali/EncodedImage$Builder;
    iget-object v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;

    invoke-interface {v0, v11}, Ljava/util/Deque;->offer(Ljava/lang/Object;)Z

    .line 255
    :try_start_d2
    iget-object v5, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
    :try_end_d4
    .catch Ljava/lang/IllegalStateException; {:try_start_d2 .. :try_end_d4} :catch_e9

    const/4 v7, 0x0

    const/4 v0, 0x0

    move v6, v12

    move/from16 v8, v19

    move-wide/from16 v20, v9

    .end local v9    # "presentationTimestampMs":J
    .local v20, "presentationTimestampMs":J
    move-wide/from16 v9, v17

    move-object/from16 v22, v11

    .end local v11    # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
    .local v22, "builder":Lorg/webrtc/ali/EncodedImage$Builder;
    move v11, v0

    :try_start_e0
    invoke-virtual/range {v5 .. v11}, Landroid/media/MediaCodec;->queueInputBuffer(IIIJI)V
    :try_end_e3
    .catch Ljava/lang/IllegalStateException; {:try_start_e0 .. :try_end_e3} :catch_e7

    .line 263
    nop

    .line 264
    sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;

    return-object v0

    .line 257
    :catch_e7
    move-exception v0

    goto :goto_ee

    .end local v20    # "presentationTimestampMs":J
    .end local v22    # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
    .restart local v9    # "presentationTimestampMs":J
    .restart local v11    # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
    :catch_e9
    move-exception v0

    move-wide/from16 v20, v9

    move-object/from16 v22, v11

    .line 258
    .end local v9    # "presentationTimestampMs":J
    .end local v11    # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
    .local v0, "e":Ljava/lang/IllegalStateException;
    .restart local v20    # "presentationTimestampMs":J
    .restart local v22    # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
    :goto_ee
    const-string v5, "queueInputBuffer failed"

    invoke-static {v2, v5, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 260
    iget-object v2, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;

    invoke-interface {v2}, Ljava/util/Deque;->pollLast()Ljava/lang/Object;

    .line 262
    sget-object v2, Lorg/webrtc/ali/VideoCodecStatus;->FALLBACK_SOFTWARE:Lorg/webrtc/ali/VideoCodecStatus;

    return-object v2

    .line 223
    .end local v0    # "e":Ljava/lang/IllegalStateException;
    .end local v13    # "buffer":Ljava/nio/ByteBuffer;
    .end local v14    # "i420":Lorg/webrtc/ali/VideoFrame$I420Buffer;
    .end local v16    # "requestedKeyFrame":Z
    .end local v17    # "presentationTimestampUs":J
    .end local v19    # "bufferSize":I
    .end local v20    # "presentationTimestampMs":J
    .end local v22    # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
    :catch_fb
    move-exception v0

    move-object/from16 v15, p2

    .line 224
    .restart local v0    # "e":Ljava/lang/IllegalStateException;
    const-string v5, "getInputBuffers failed"

    invoke-static {v2, v5, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 225
    sget-object v2, Lorg/webrtc/ali/VideoCodecStatus;->FALLBACK_SOFTWARE:Lorg/webrtc/ali/VideoCodecStatus;

    return-object v2

    .line 203
    .end local v0    # "e":Ljava/lang/IllegalStateException;
    .end local v12    # "index":I
    :catch_106
    move-exception v0

    move-object/from16 v15, p2

    .line 204
    .restart local v0    # "e":Ljava/lang/IllegalStateException;
    const-string v5, "dequeueInputBuffer failed"

    invoke-static {v2, v5, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 205
    sget-object v2, Lorg/webrtc/ali/VideoCodecStatus;->FALLBACK_SOFTWARE:Lorg/webrtc/ali/VideoCodecStatus;

    return-object v2
.end method

.method public getImplementationName()Ljava/lang/String;
    .registers 3

    .line 290
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "HardwareVideoEncoder: "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecName:Ljava/lang/String;

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    return-object v0
.end method

.method public getScalingSettings()Lorg/webrtc/ali/VideoEncoder$ScalingSettings;
    .registers 2

    .line 285
    const/4 v0, 0x0

    return-object v0
.end method

.method public initEncode(Lorg/webrtc/ali/VideoEncoder$Settings;Lorg/webrtc/ali/VideoEncoder$Callback;)Lorg/webrtc/ali/VideoCodecStatus;
    .registers 9
    .param p1, "settings"    # Lorg/webrtc/ali/VideoEncoder$Settings;
    .param p2, "callback"    # Lorg/webrtc/ali/VideoEncoder$Callback;

    .line 113
    iget v1, p1, Lorg/webrtc/ali/VideoEncoder$Settings;->width:I

    iget v2, p1, Lorg/webrtc/ali/VideoEncoder$Settings;->height:I

    iget v3, p1, Lorg/webrtc/ali/VideoEncoder$Settings;->startBitrate:I

    iget v4, p1, Lorg/webrtc/ali/VideoEncoder$Settings;->maxFramerate:I

    move-object v0, p0

    move-object v5, p2

    invoke-direct/range {v0 .. v5}, Lorg/webrtc/ali/HardwareVideoEncoder;->initEncodeInternal(IIIILorg/webrtc/ali/VideoEncoder$Callback;)Lorg/webrtc/ali/VideoCodecStatus;

    move-result-object v0

    return-object v0
.end method

.method public release()Lorg/webrtc/ali/VideoCodecStatus;
    .registers 5

    .line 165
    const/4 v0, 0x0

    const/4 v1, 0x0

    :try_start_2
    iput-boolean v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->running:Z

    .line 166
    iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputThread:Ljava/lang/Thread;

    const-wide/16 v2, 0x1388

    invoke-static {v0, v2, v3}, Lorg/webrtc/ali/ThreadUtils;->joinUninterruptibly(Ljava/lang/Thread;J)Z

    move-result v0
    :try_end_c
    .catchall {:try_start_2 .. :try_end_c} :catchall_45

    const-string v2, "HardwareVideoEncoder"

    if-nez v0, :cond_21

    .line 167
    :try_start_10
    const-string v0, "Media encoder release timeout"

    invoke-static {v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 168
    sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->TIMEOUT:Lorg/webrtc/ali/VideoCodecStatus;
    :try_end_17
    .catchall {:try_start_10 .. :try_end_17} :catchall_45

    .line 176
    iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    .line 177
    iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputThread:Ljava/lang/Thread;

    .line 178
    iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;

    invoke-interface {v1}, Ljava/util/Deque;->clear()V

    .line 168
    return-object v0

    .line 170
    :cond_21
    :try_start_21
    iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->shutdownException:Ljava/lang/Exception;

    if-eqz v0, :cond_38

    .line 172
    const-string v0, "Media encoder release exception"

    iget-object v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->shutdownException:Ljava/lang/Exception;

    invoke-static {v2, v0, v3}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 173
    sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->ERROR:Lorg/webrtc/ali/VideoCodecStatus;
    :try_end_2e
    .catchall {:try_start_21 .. :try_end_2e} :catchall_45

    .line 176
    iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    .line 177
    iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputThread:Ljava/lang/Thread;

    .line 178
    iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;

    invoke-interface {v1}, Ljava/util/Deque;->clear()V

    .line 173
    return-object v0

    .line 176
    :cond_38
    iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    .line 177
    iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputThread:Ljava/lang/Thread;

    .line 178
    iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;

    invoke-interface {v0}, Ljava/util/Deque;->clear()V

    .line 179
    nop

    .line 180
    sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;

    return-object v0

    .line 176
    :catchall_45
    move-exception v0

    iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;

    .line 177
    iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputThread:Ljava/lang/Thread;

    .line 178
    iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;

    invoke-interface {v1}, Ljava/util/Deque;->clear()V

    .line 179
    throw v0
.end method

.method public setChannelParameters(SJ)Lorg/webrtc/ali/VideoCodecStatus;
    .registers 5
    .param p1, "packetLoss"    # S
    .param p2, "roundTripTimeMs"    # J

    .line 270
    sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;

    return-object v0
.end method

.method public setRateAllocation(Lorg/webrtc/ali/VideoEncoder$BitrateAllocation;I)Lorg/webrtc/ali/VideoCodecStatus;
    .registers 5
    .param p1, "bitrateAllocation"    # Lorg/webrtc/ali/VideoEncoder$BitrateAllocation;
    .param p2, "framerate"    # I

    .line 275
    const/16 v0, 0x1e

    if-le p2, v0, :cond_6

    .line 276
    const/16 p2, 0x1e

    .line 278
    :cond_6
    iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;

    invoke-virtual {p1}, Lorg/webrtc/ali/VideoEncoder$BitrateAllocation;->getSum()I

    move-result v1

    invoke-interface {v0, v1, p2}, Lorg/webrtc/ali/BitrateAdjuster;->setTargets(II)V

    .line 279
    invoke-direct {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->updateBitrate()Lorg/webrtc/ali/VideoCodecStatus;

    move-result-object v0

    return-object v0
.end method