HardwareVideoDecoder2.smali 
.class public Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Landroid/graphics/SurfaceTexture$OnFrameAvailableListener;
# annotations
.annotation runtime Lcom/tencent/liteav/base/annotations/JNINamespace;
    value = "liteav::video"
.end annotation
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;
    }
.end annotation
# static fields
.field private static final DRAIN_ERROR:I = -0x1
.field private static final DRAIN_SUCCESS:I = 0x0
.field private static final DRAIN_SUCCESS_MEET_END_OF_STREAM:I = 0x1
# instance fields
.field private final mBufferInfo:Landroid/media/MediaCodec$BufferInfo;
.field private final mDecoderMediaFormatBuilder:Lcom/tencent/liteav/videobase/utils/h;
.field private mEnableLimitMaxDecFrameBufferingInH264Sps:Z
.field private mIsRealTime:Z
.field private mIsStarted:Z
.field private mMediaCodec:Landroid/media/MediaCodec;
.field private mNativeVideoDecoderImplAndroid:J
.field private mOutputSurface:Landroid/view/Surface;
.field private final mSPSModifier:Lcom/tencent/liteav/videoconsumer/decoder/s;
.field private mSurfaceTexture:Landroid/graphics/SurfaceTexture;
.field private final mTAG:Ljava/lang/String;
.field private final mThrottlers:Lcom/tencent/liteav/base/b/b;
# direct methods
.method constructor <init>(ZZIIJ)V
    .registers 9
    .line 54
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V
    .line 33
    new-instance v0, Ljava/lang/StringBuilder;
    const-string v1, "HardwareVideoDecoder2_"
    invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
    invoke-virtual {p0}, Ljava/lang/Object;->hashCode()I
    move-result v1
    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v0
    iput-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    .line 39
    new-instance v0, Lcom/tencent/liteav/base/b/b;
    invoke-direct {v0}, Lcom/tencent/liteav/base/b/b;-><init>()V
    iput-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mThrottlers:Lcom/tencent/liteav/base/b/b;
    const/4 v0, 0x0
    .line 43
    iput-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
    .line 46
    new-instance v0, Landroid/media/MediaCodec$BufferInfo;
    invoke-direct {v0}, Landroid/media/MediaCodec$BufferInfo;-><init>()V
    iput-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mBufferInfo:Landroid/media/MediaCodec$BufferInfo;
    const/4 v0, 0x0
    .line 49
    iput-boolean v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mEnableLimitMaxDecFrameBufferingInH264Sps:Z
    .line 50
    new-instance v0, Lcom/tencent/liteav/videoconsumer/decoder/s;
    invoke-direct {v0}, Lcom/tencent/liteav/videoconsumer/decoder/s;-><init>()V
    iput-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSPSModifier:Lcom/tencent/liteav/videoconsumer/decoder/s;
    .line 55
    iput-boolean p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mIsRealTime:Z
    .line 56
    iput-wide p5, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mNativeVideoDecoderImplAndroid:J
    .line 58
    new-instance p1, Lcom/tencent/liteav/videobase/utils/h;
    invoke-direct {p1}, Lcom/tencent/liteav/videobase/utils/h;-><init>()V
    if-eqz p2, :cond_40
    const-string p2, "video/hevc"
    goto :goto_42
    :cond_40
    const-string p2, "video/avc"
    .line 1077
    :goto_42
    iput-object p2, p1, Lcom/tencent/liteav/videobase/utils/h;->e:Ljava/lang/String;
    .line 2067
    iput p3, p1, Lcom/tencent/liteav/videobase/utils/h;->c:I
    .line 2072
    iput p4, p1, Lcom/tencent/liteav/videobase/utils/h;->d:I
    .line 61
    iput-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mDecoderMediaFormatBuilder:Lcom/tencent/liteav/videobase/utils/h;
    return-void
.end method
.method private configureDecoder(Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;Z)Z
    .registers 9
    .line 346
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mDecoderMediaFormatBuilder:Lcom/tencent/liteav/videobase/utils/h;
    .line 2082
    iput-boolean p2, v0, Lcom/tencent/liteav/videobase/utils/h;->f:Z
    .line 347
    iget-object p2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mDecoderMediaFormatBuilder:Lcom/tencent/liteav/videobase/utils/h;
    invoke-virtual {p2}, Lcom/tencent/liteav/videobase/utils/h;->a()Landroid/media/MediaFormat;
    move-result-object p2
    .line 348
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    invoke-static {p2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
    move-result-object v1
    const-string v2, "mediaFormat:"
    invoke-virtual {v2, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
    move-result-object v1
    invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    const/4 v0, 0x0
    const/4 v1, 0x0
    :try_start_1b
    const-string v2, "mime"
    .line 351
    invoke-virtual {p2, v2}, Landroid/media/MediaFormat;->getString(Ljava/lang/String;)Ljava/lang/String;
    move-result-object v2
    .line 352
    invoke-static {v2}, Landroid/media/MediaCodec;->createDecoderByType(Ljava/lang/String;)Landroid/media/MediaCodec;
    move-result-object v2
    iput-object v2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
    .line 353
    iget-object v2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
    iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mOutputSurface:Landroid/view/Surface;
    invoke-virtual {v2, p2, v3, v0, v1}, Landroid/media/MediaCodec;->configure(Landroid/media/MediaFormat;Landroid/view/Surface;Landroid/media/MediaCrypto;I)V
    .line 354
    iget-object p2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
    const/4 v2, 0x1
    invoke-virtual {p2, v2}, Landroid/media/MediaCodec;->setVideoScalingMode(I)V
    .line 356
    iget-object p2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
    invoke-virtual {p2}, Landroid/media/MediaCodec;->start()V
    .line 357
    iget-object p2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v3, "Start MediaCodec(%s) success."
    new-array v4, v2, [Ljava/lang/Object;
    iget-object v5, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
    .line 358
    invoke-virtual {v5}, Landroid/media/MediaCodec;->getName()Ljava/lang/String;
    move-result-object v5
    aput-object v5, v4, v1
    .line 357
    invoke-static {p2, v3, v4}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    :try_end_4a
    .catch Ljava/lang/Exception; {:try_start_1b .. :try_end_4a} :catch_4b
    return v2
    :catch_4b
    move-exception p2
    .line 361
    iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v3, "Start MediaCodec failed."
    invoke-static {v2, v3, p2}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .line 362
    iget-object v2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
    invoke-direct {p0, v2}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->destroyMediaCodec(Landroid/media/MediaCodec;)V
    .line 363
    iput-object v0, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
    .line 364
    sget-object v0, Lcom/tencent/liteav/videobase/videobase/h$c;->m:Lcom/tencent/liteav/videobase/videobase/h$c;
    .line 367
    instance-of v2, p2, Ljava/lang/IllegalArgumentException;
    if-eqz v2, :cond_65
    .line 368
    sget-object v0, Lcom/tencent/liteav/videobase/videobase/h$c;->i:Lcom/tencent/liteav/videobase/videobase/h$c;
    const-string v2, "VideoDecode: illegal argument, Start decoder failed"
    goto :goto_70
    .line 371
    :cond_65
    instance-of v2, p2, Ljava/lang/IllegalStateException;
    if-eqz v2, :cond_6e
    .line 372
    sget-object v0, Lcom/tencent/liteav/videobase/videobase/h$c;->j:Lcom/tencent/liteav/videobase/videobase/h$c;
    const-string v2, "VideoDecode: illegal state, Start decoder failed"
    goto :goto_70
    :cond_6e
    const-string v2, "VideoDecode: Start decoder failed"
    .line 375
    :goto_70
    iput-object v0, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->b:Lcom/tencent/liteav/videobase/videobase/h$c;
    .line 376
    iput-object v2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->c:Ljava/lang/String;
    .line 377
    iput-object p2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->d:Ljava/lang/Exception;
    return v1
.end method
.method private destroyMediaCodec(Landroid/media/MediaCodec;)V
    .registers 8
    const-string v0, "release MediaCodec failed."
    const-string v1, "mediaCodec release"
    if-eqz p1, :cond_53
    .line 385
    :try_start_6
    iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v3, "mediaCodec stop"
    invoke-static {v2, v3}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    .line 386
    invoke-virtual {p1}, Landroid/media/MediaCodec;->stop()V
    :try_end_10
    .catch Ljava/lang/Exception; {:try_start_6 .. :try_end_10} :catch_22
    .catchall {:try_start_6 .. :try_end_10} :catchall_20
    .line 391
    :try_start_10
    iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    invoke-static {v2, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    .line 392
    invoke-virtual {p1}, Landroid/media/MediaCodec;->release()V
    :try_end_18
    .catch Ljava/lang/Exception; {:try_start_10 .. :try_end_18} :catch_19
    return-void
    :catch_19
    move-exception p1
    .line 394
    iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    invoke-static {v1, v0, p1}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    return-void
    :catchall_20
    move-exception v2
    goto :goto_43
    :catch_22
    move-exception v2
    .line 388
    :try_start_23
    iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    new-instance v4, Ljava/lang/StringBuilder;
    const-string v5, "Stop MediaCodec failed."
    invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
    invoke-virtual {v2}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
    move-result-object v2
    invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v2
    invoke-static {v3, v2}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_3a
    .catchall {:try_start_23 .. :try_end_3a} :catchall_20
    .line 391
    :try_start_3a
    iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    invoke-static {v2, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    .line 392
    invoke-virtual {p1}, Landroid/media/MediaCodec;->release()V
    :try_end_42
    .catch Ljava/lang/Exception; {:try_start_3a .. :try_end_42} :catch_19
    return-void
    .line 391
    :goto_43
    :try_start_43
    iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    invoke-static {v3, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    .line 392
    invoke-virtual {p1}, Landroid/media/MediaCodec;->release()V
    :try_end_4b
    .catch Ljava/lang/Exception; {:try_start_43 .. :try_end_4b} :catch_4c
    goto :goto_52
    :catch_4c
    move-exception p1
    .line 394
    iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    invoke-static {v1, v0, p1}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .line 396
    :goto_52
    throw v2
    :cond_53
    return-void
.end method
.method private drainDecodedFrameInternal()I
    .registers 9
    const/4 v0, 0x0
    move v1, v0
    :goto_2
    const/4 v2, 0x3
    const/4 v3, -0x1
    if-ge v1, v2, :cond_55
    .line 216
    iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
    iget-object v4, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mBufferInfo:Landroid/media/MediaCodec$BufferInfo;
    sget-object v5, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
    const-wide/16 v6, 0xa
    .line 217
    invoke-virtual {v5, v6, v7}, Ljava/util/concurrent/TimeUnit;->toMicros(J)J
    move-result-wide v5
    invoke-virtual {v2, v4, v5, v6}, Landroid/media/MediaCodec;->dequeueOutputBuffer(Landroid/media/MediaCodec$BufferInfo;J)I
    move-result v2
    if-ne v2, v3, :cond_19
    return v3
    :cond_19
    const/4 v4, -0x3
    if-ne v2, v4, :cond_24
    .line 222
    iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v3, "on output buffers changed"
    invoke-static {v2, v3}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    goto :goto_2a
    :cond_24
    const/4 v4, -0x2
    if-ne v2, v4, :cond_2d
    .line 224
    invoke-direct {p0}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->outputFormatChange()V
    :goto_2a
    add-int/lit8 v1, v1, 0x1
    goto :goto_2
    :cond_2d
    const/4 v1, 0x1
    if-ltz v2, :cond_46
    .line 226
    iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
    invoke-virtual {v3, v2, v1}, Landroid/media/MediaCodec;->releaseOutputBuffer(IZ)V
    .line 227
    iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mBufferInfo:Landroid/media/MediaCodec$BufferInfo;
    iget v2, v2, Landroid/media/MediaCodec$BufferInfo;->flags:I
    and-int/lit8 v2, v2, 0x4
    if-eqz v2, :cond_45
    .line 228
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v2, "meet end of stream."
    invoke-static {v0, v2}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    return v1
    :cond_45
    return v0
    .line 235
    :cond_46
    iget-object v4, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    new-array v1, v1, [Ljava/lang/Object;
    invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
    move-result-object v2
    aput-object v2, v1, v0
    const-string v0, "dequeueOutputBuffer get invalid index: %d"
    invoke-static {v4, v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->d(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    :cond_55
    return v3
.end method
.method private feedDataToMediaCodec(Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;)Z
    .registers 15
    .line 168
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
    const/4 v1, 0x0
    if-nez v0, :cond_d
    .line 169
    iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v0, "MediaCodec is stopped."
    invoke-static {p1, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->w(Ljava/lang/String;Ljava/lang/String;)V
    return v1
    :cond_d
    const/4 v0, 0x1
    if-eqz p1, :cond_76
    .line 173
    iget-boolean v2, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->isEosFrame:Z
    if-nez v2, :cond_21
    iget-object v2, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
    if-eqz v2, :cond_76
    iget-object v2, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
    .line 174
    invoke-virtual {v2}, Ljava/nio/ByteBuffer;->remaining()I
    move-result v2
    if-nez v2, :cond_21
    goto :goto_76
    .line 179
    :cond_21
    iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
    invoke-virtual {v2}, Landroid/media/MediaCodec;->getInputBuffers()[Ljava/nio/ByteBuffer;
    move-result-object v2
    .line 180
    invoke-static {v2}, Lcom/tencent/liteav/videobase/utils/c;->a([Ljava/lang/Object;)Z
    move-result v3
    if-eqz v3, :cond_35
    .line 181
    iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v0, "get invalid input buffers."
    invoke-static {p1, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;)V
    return v1
    .line 185
    :cond_35
    iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
    const-wide/16 v4, 0x2710
    invoke-virtual {v3, v4, v5}, Landroid/media/MediaCodec;->dequeueInputBuffer(J)I
    move-result v7
    if-gez v7, :cond_40
    return v1
    .line 189
    :cond_40
    iget-boolean v1, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->isEosFrame:Z
    if-nez v1, :cond_64
    .line 190
    invoke-direct {p0, p1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->limitMaxDecFrameBufferingInH264Sps(Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;)V
    .line 191
    iget-object v1, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
    invoke-virtual {v1}, Ljava/nio/ByteBuffer;->remaining()I
    move-result v9
    .line 192
    aget-object v1, v2, v7
    iget-object v2, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
    invoke-virtual {v1, v2}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
    .line 193
    iget-object v6, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
    const/4 v8, 0x0
    sget-object v1, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
    iget-wide v2, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->pts:J
    .line 194
    invoke-virtual {v1, v2, v3}, Ljava/util/concurrent/TimeUnit;->toMicros(J)J
    move-result-wide v10
    const/4 v12, 0x0
    .line 193
    invoke-virtual/range {v6 .. v12}, Landroid/media/MediaCodec;->queueInputBuffer(IIIJI)V
    goto :goto_75
    .line 196
    :cond_64
    iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v1, "feedDataToMediaCodec BUFFER_FLAG_END_OF_STREAM"
    invoke-static {p1, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    .line 197
    iget-object v6, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
    const/4 v8, 0x0
    const/4 v9, 0x0
    const-wide/16 v10, 0x0
    const/4 v12, 0x4
    invoke-virtual/range {v6 .. v12}, Landroid/media/MediaCodec;->queueInputBuffer(IIIJI)V
    :goto_75
    return v0
    .line 175
    :cond_76
    :goto_76
    iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v1, "receive empty buffer."
    invoke-static {p1, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->w(Ljava/lang/String;Ljava/lang/String;)V
    return v0
.end method
.method private getSpsData([B[I)[B
    .registers 9
    const/4 v0, 0x0
    move v1, v0
    :cond_2
    add-int/lit8 v2, v1, 0x4
    .line 283
    array-length v3, p1
    if-ge v2, v3, :cond_1a
    .line 284
    invoke-static {p1}, Ljava/nio/ByteBuffer;->wrap([B)Ljava/nio/ByteBuffer;
    move-result-object v2
    invoke-static {v1, v2}, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->getNextNALHeaderPos(ILjava/nio/ByteBuffer;)I
    move-result v1
    if-ltz v1, :cond_1a
    .line 288
    aget-byte v2, p1, v1
    and-int/lit8 v2, v2, 0x1f
    const/4 v3, 0x7
    if-ne v2, v3, :cond_2
    .line 289
    aput v1, p2, v0
    .line 293
    :cond_1a
    aget v1, p2, v0
    if-gez v1, :cond_20
    const/4 p1, 0x0
    return-object p1
    .line 296
    :cond_20
    array-length v1, p1
    aget v2, p2, v0
    sub-int/2addr v1, v2
    .line 297
    aget v2, p2, v0
    :goto_26
    add-int/lit8 v3, v2, 0x3
    array-length v4, p1
    if-ge v3, v4, :cond_58
    .line 298
    aget-byte v4, p1, v2
    const/4 v5, 0x1
    if-nez v4, :cond_3c
    add-int/lit8 v4, v2, 0x1
    aget-byte v4, p1, v4
    if-nez v4, :cond_3c
    add-int/lit8 v4, v2, 0x2
    aget-byte v4, p1, v4
    if-eq v4, v5, :cond_50
    :cond_3c
    aget-byte v4, p1, v2
    if-nez v4, :cond_55
    add-int/lit8 v4, v2, 0x1
    aget-byte v4, p1, v4
    if-nez v4, :cond_55
    add-int/lit8 v4, v2, 0x2
    aget-byte v4, p1, v4
    if-nez v4, :cond_55
    aget-byte v3, p1, v3
    if-ne v3, v5, :cond_55
    .line 301
    :cond_50
    aget v1, p2, v0
    sub-int v1, v2, v1
    goto :goto_58
    :cond_55
    add-int/lit8 v2, v2, 0x1
    goto :goto_26
    .line 305
    :cond_58
    :goto_58
    new-array v2, v1, [B
    .line 306
    aget p2, p2, v0
    invoke-static {p1, p2, v2, v0, v1}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
    return-object v2
.end method
.method private varargs handleDecoderError(Lcom/tencent/liteav/videobase/videobase/h$c;Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 5
    .line 401
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    invoke-static {v0, p2, p3}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    .line 402
    iget-wide p2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mNativeVideoDecoderImplAndroid:J
    .line 403
    invoke-static {p1}, Lcom/tencent/liteav/videobase/videobase/h;->a(Lcom/tencent/liteav/videobase/videobase/h$c;)I
    move-result p1
    .line 402
    invoke-direct {p0, p2, p3, p1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->nativeOnDecodedFrameFailed(JI)V
    return-void
.end method
.method private initializeSurface(I)Z
    .registers 6
    .line 311
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v1, "initialize surface"
    invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    .line 312
    monitor-enter p0
    const/4 v0, 0x0
    .line 314
    :try_start_9
    new-instance v1, Landroid/graphics/SurfaceTexture;
    invoke-direct {v1, p1}, Landroid/graphics/SurfaceTexture;-><init>(I)V
    iput-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
    .line 315
    new-instance p1, Landroid/view/Surface;
    iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
    invoke-direct {p1, v1}, Landroid/view/Surface;-><init>(Landroid/graphics/SurfaceTexture;)V
    iput-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mOutputSurface:Landroid/view/Surface;
    .line 316
    iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
    invoke-virtual {p1, p0}, Landroid/graphics/SurfaceTexture;->setOnFrameAvailableListener(Landroid/graphics/SurfaceTexture$OnFrameAvailableListener;)V
    :try_end_1e
    .catch Landroid/view/Surface$OutOfResourcesException; {:try_start_9 .. :try_end_1e} :catch_34
    .catchall {:try_start_9 .. :try_end_1e} :catchall_32
    .line 325
    :try_start_1e
    monitor-exit p0
    :try_end_1f
    .catchall {:try_start_1e .. :try_end_1f} :catchall_32
    .line 327
    iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mThrottlers:Lcom/tencent/liteav/base/b/b;
    const-string v1, "initializeSurface"
    invoke-virtual {p1, v1}, Lcom/tencent/liteav/base/b/b;->a(Ljava/lang/String;)Lcom/tencent/liteav/base/b/a;
    move-result-object p1
    iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v2, "initializeSurface"
    new-array v0, v0, [Ljava/lang/Object;
    invoke-static {p1, v1, v2, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Lcom/tencent/liteav/base/b/a;Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    const/4 p1, 0x1
    return p1
    :catchall_32
    move-exception p1
    goto :goto_5f
    :catch_34
    move-exception p1
    .line 318
    :try_start_35
    iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mThrottlers:Lcom/tencent/liteav/base/b/b;
    const-string v2, "surface"
    invoke-virtual {v1, v2}, Lcom/tencent/liteav/base/b/b;->a(Ljava/lang/String;)Lcom/tencent/liteav/base/b/a;
    move-result-object v1
    iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v3, "create SurfaceTexture failed."
    invoke-static {v1, v2, v3, p1}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Lcom/tencent/liteav/base/b/a;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .line 319
    sget-object v1, Lcom/tencent/liteav/videobase/videobase/h$c;->k:Lcom/tencent/liteav/videobase/videobase/h$c;
    new-instance v2, Ljava/lang/StringBuilder;
    const-string v3, "VideoDecode: insufficient resource, Start decoder failed:"
    invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
    .line 322
    invoke-virtual {p1}, Landroid/view/Surface$OutOfResourcesException;->getMessage()Ljava/lang/String;
    move-result-object p1
    invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p1
    new-array v2, v0, [Ljava/lang/Object;
    .line 319
    invoke-direct {p0, v1, p1, v2}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->handleDecoderError(Lcom/tencent/liteav/videobase/videobase/h$c;Ljava/lang/String;[Ljava/lang/Object;)V
    .line 323
    monitor-exit p0
    return v0
    .line 325
    :goto_5f
    monitor-exit p0
    :try_end_60
    .catchall {:try_start_35 .. :try_end_60} :catchall_32
    throw p1
.end method
.method private limitMaxDecFrameBufferingInH264Sps(Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;)V
    .registers 10
    .line 243
    invoke-virtual {p1}, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->isIDRFrame()Z
    move-result v0
    if-eqz v0, :cond_7f
    iget-object v0, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->codecType:Lcom/tencent/liteav/videobase/common/CodecType;
    sget-object v1, Lcom/tencent/liteav/videobase/common/CodecType;->b:Lcom/tencent/liteav/videobase/common/CodecType;
    if-ne v0, v1, :cond_7f
    iget-boolean v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mEnableLimitMaxDecFrameBufferingInH264Sps:Z
    if-nez v0, :cond_11
    goto :goto_7f
    .line 247
    :cond_11
    iget-object v0, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
    invoke-virtual {v0}, Ljava/nio/ByteBuffer;->remaining()I
    move-result v0
    invoke-static {v0}, Lcom/tencent/liteav/videobase/utils/j;->a(I)[B
    move-result-object v0
    if-nez v0, :cond_1e
    return-void
    .line 251
    :cond_1e
    iget-object v1, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
    invoke-virtual {v1, v0}, Ljava/nio/ByteBuffer;->get([B)Ljava/nio/ByteBuffer;
    .line 252
    iget-object v1, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
    invoke-virtual {v1}, Ljava/nio/ByteBuffer;->rewind()Ljava/nio/Buffer;
    const/4 v1, 0x1
    new-array v1, v1, [I
    const/4 v2, -0x1
    const/4 v3, 0x0
    aput v2, v1, v3
    .line 254
    invoke-direct {p0, v0, v1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->getSpsData([B[I)[B
    move-result-object v2
    if-eqz v2, :cond_7f
    .line 255
    aget v4, v1, v3
    if-gez v4, :cond_3a
    goto :goto_7f
    :cond_3a
    const/4 v4, 0x0
    .line 260
    :try_start_3b
    iget-object v5, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSPSModifier:Lcom/tencent/liteav/videoconsumer/decoder/s;
    invoke-virtual {v5, v2}, Lcom/tencent/liteav/videoconsumer/decoder/s;->a([B)[B
    move-result-object v4
    :try_end_41
    .catch Ljava/lang/Exception; {:try_start_3b .. :try_end_41} :catch_42
    goto :goto_4a
    :catch_42
    move-exception v5
    .line 262
    iget-object v6, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v7, "modify dec buffer error "
    invoke-static {v6, v7, v5}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    :goto_4a
    if-nez v4, :cond_4d
    return-void
    .line 267
    :cond_4d
    array-length v5, v0
    array-length v6, v2
    sub-int/2addr v5, v6
    array-length v6, v4
    add-int/2addr v5, v6
    invoke-static {v5}, Lcom/tencent/liteav/videobase/utils/j;->b(I)Ljava/nio/ByteBuffer;
    move-result-object v5
    if-nez v5, :cond_59
    return-void
    .line 271
    :cond_59
    iput-object v5, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
    .line 272
    aget v5, v1, v3
    if-lez v5, :cond_66
    .line 273
    iget-object v5, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
    aget v6, v1, v3
    invoke-virtual {v5, v0, v3, v6}, Ljava/nio/ByteBuffer;->put([BII)Ljava/nio/ByteBuffer;
    .line 275
    :cond_66
    iget-object v5, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
    invoke-virtual {v5, v4}, Ljava/nio/ByteBuffer;->put([B)Ljava/nio/ByteBuffer;
    .line 276
    iget-object v4, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
    aget v5, v1, v3
    array-length v6, v2
    add-int/2addr v5, v6
    array-length v6, v0
    aget v1, v1, v3
    sub-int/2addr v6, v1
    array-length v1, v2
    sub-int/2addr v6, v1
    invoke-virtual {v4, v0, v5, v6}, Ljava/nio/ByteBuffer;->put([BII)Ljava/nio/ByteBuffer;
    .line 278
    iget-object p1, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
    invoke-virtual {p1}, Ljava/nio/ByteBuffer;->rewind()Ljava/nio/Buffer;
    :cond_7f
    :goto_7f
    return-void
.end method
.method private native nativeOnDecodedFrameFailed(JI)V
.end method
.method private native nativeOnFrameAvailable(JJ)V
.end method
.method private outputFormatChange()V
    .registers 9
    .line 407
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
    invoke-virtual {v0}, Landroid/media/MediaCodec;->getOutputFormat()Landroid/media/MediaFormat;
    move-result-object v0
    .line 408
    iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
    move-result-object v2
    const-string v3, "decode output format changed: "
    invoke-virtual {v3, v2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
    move-result-object v2
    invoke-static {v1, v2}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    const-string v1, "crop-right"
    .line 411
    invoke-virtual {v0, v1}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v1
    const-string v2, "crop-left"
    invoke-virtual {v0, v2}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v2
    sub-int/2addr v1, v2
    invoke-static {v1}, Ljava/lang/Math;->abs(I)I
    move-result v1
    const/4 v2, 0x1
    add-int/2addr v1, v2
    const-string v3, "crop-bottom"
    .line 413
    invoke-virtual {v0, v3}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v3
    const-string v4, "crop-top"
    invoke-virtual {v0, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v4
    sub-int/2addr v3, v4
    invoke-static {v3}, Ljava/lang/Math;->abs(I)I
    move-result v3
    add-int/2addr v3, v2
    const-string/jumbo v4, "width"
    .line 414
    invoke-virtual {v0, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v4
    const-string v5, "height"
    .line 415
    invoke-virtual {v0, v5}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v0
    .line 416
    iget-object v5, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const/4 v6, 0x4
    new-array v6, v6, [Ljava/lang/Object;
    .line 417
    invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
    move-result-object v1
    const/4 v7, 0x0
    aput-object v1, v6, v7
    invoke-static {v3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
    move-result-object v1
    aput-object v1, v6, v2
    invoke-static {v4}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
    move-result-object v1
    const/4 v2, 0x2
    aput-object v1, v6, v2
    invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
    move-result-object v0
    const/4 v1, 0x3
    aput-object v0, v6, v1
    const-string v0, "cropWidth: %d, cropHeight: %d, frameWidth: %d, frameHeight: %d"
    .line 416
    invoke-static {v5, v0, v6}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    return-void
.end method
.method private uninitializeSurface()V
    .registers 3
    .line 332
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v1, "uninitialize surface"
    invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    .line 333
    monitor-enter p0
    .line 334
    :try_start_8
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mOutputSurface:Landroid/view/Surface;
    const/4 v1, 0x0
    if-eqz v0, :cond_12
    .line 335
    invoke-virtual {v0}, Landroid/view/Surface;->release()V
    .line 336
    iput-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mOutputSurface:Landroid/view/Surface;
    .line 338
    :cond_12
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
    if-eqz v0, :cond_1b
    .line 339
    invoke-virtual {v0}, Landroid/graphics/SurfaceTexture;->release()V
    .line 340
    iput-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
    .line 342
    :cond_1b
    monitor-exit p0
    return-void
    :catchall_1d
    move-exception v0
    monitor-exit p0
    :try_end_1f
    .catchall {:try_start_8 .. :try_end_1f} :catchall_1d
    throw v0
.end method
# virtual methods
.method public decodeFrame(Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;)Z
    .registers 8
    .line 122
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
    const/4 v1, 0x0
    if-nez v0, :cond_d
    .line 123
    iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v0, "MediaCodec is stopped."
    invoke-static {p1, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->w(Ljava/lang/String;Ljava/lang/String;)V
    return v1
    :cond_d
    const/4 v0, 0x1
    if-nez p1, :cond_11
    return v0
    .line 132
    :cond_11
    :try_start_11
    invoke-direct {p0, p1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->feedDataToMediaCodec(Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;)Z
    move-result v2
    if-nez v2, :cond_3c
    .line 133
    invoke-virtual {p1}, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->release()V
    :try_end_1a
    .catch Ljava/lang/Exception; {:try_start_11 .. :try_end_1a} :catch_1b
    return v1
    :catch_1b
    move-exception v2
    .line 137
    iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v4, "decode failed."
    invoke-static {v3, v4, v2}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .line 138
    sget-object v3, Lcom/tencent/liteav/videobase/videobase/h$c;->n:Lcom/tencent/liteav/videobase/videobase/h$c;
    new-instance v4, Ljava/lang/StringBuilder;
    const-string v5, "VideoDecode: decode error, restart decoder message:"
    invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
    .line 139
    invoke-virtual {v2}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
    move-result-object v2
    invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v2
    new-array v1, v1, [Ljava/lang/Object;
    .line 138
    invoke-direct {p0, v3, v2, v1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->handleDecoderError(Lcom/tencent/liteav/videobase/videobase/h$c;Ljava/lang/String;[Ljava/lang/Object;)V
    .line 141
    :cond_3c
    invoke-virtual {p1}, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->release()V
    return v0
.end method
.method public drainDecodedFrame()I
    .registers 5
    .line 111
    :try_start_0
    invoke-direct {p0}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->drainDecodedFrameInternal()I
    move-result v0
    :try_end_4
    .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_4} :catch_5
    return v0
    :catch_5
    move-exception v0
    .line 113
    iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v2, "decode failed."
    invoke-static {v1, v2, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .line 114
    sget-object v1, Lcom/tencent/liteav/videobase/videobase/h$c;->n:Lcom/tencent/liteav/videobase/videobase/h$c;
    new-instance v2, Ljava/lang/StringBuilder;
    const-string v3, "VideoDecode: decode error, restart decoder message:"
    invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
    .line 115
    invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
    move-result-object v0
    invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v0
    const/4 v2, 0x0
    new-array v2, v2, [Ljava/lang/Object;
    .line 114
    invoke-direct {p0, v1, v0, v2}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->handleDecoderError(Lcom/tencent/liteav/videobase/videobase/h$c;Ljava/lang/String;[Ljava/lang/Object;)V
    const/4 v0, -0x1
    return v0
.end method
.method public onFrameAvailable(Landroid/graphics/SurfaceTexture;)V
    .registers 6
    .line 423
    monitor-enter p0
    .line 424
    :try_start_1
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
    if-eqz v0, :cond_29
    if-eq v0, p1, :cond_8
    goto :goto_29
    .line 427
    :cond_8
    sget-object v0, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;
    invoke-virtual {p1}, Landroid/graphics/SurfaceTexture;->getTimestamp()J
    move-result-wide v1
    invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
    move-result-wide v0
    const-wide/16 v2, 0x0
    cmp-long p1, v0, v2
    if-nez p1, :cond_22
    .line 431
    sget-object p1, Ljava/util/concurrent/TimeUnit;->MICROSECONDS:Ljava/util/concurrent/TimeUnit;
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mBufferInfo:Landroid/media/MediaCodec$BufferInfo;
    iget-wide v0, v0, Landroid/media/MediaCodec$BufferInfo;->presentationTimeUs:J
    invoke-virtual {p1, v0, v1}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
    move-result-wide v0
    .line 433
    :cond_22
    monitor-exit p0
    :try_end_23
    .catchall {:try_start_1 .. :try_end_23} :catchall_2b
    .line 434
    iget-wide v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mNativeVideoDecoderImplAndroid:J
    invoke-direct {p0, v2, v3, v0, v1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->nativeOnFrameAvailable(JJ)V
    return-void
    .line 425
    :cond_29
    :goto_29
    :try_start_29
    monitor-exit p0
    return-void
    :catchall_2b
    move-exception p1
    .line 433
    monitor-exit p0
    :try_end_2d
    .catchall {:try_start_29 .. :try_end_2d} :catchall_2b
    throw p1
.end method
.method public setEnableVui(Z)V
    .registers 2
    .line 147
    iput-boolean p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mEnableLimitMaxDecFrameBufferingInH264Sps:Z
    return-void
.end method
.method public start(I)Z
    .registers 6
    .line 67
    iget-boolean v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mIsStarted:Z
    const/4 v1, 0x1
    if-eqz v0, :cond_6
    return v1
    .line 70
    :cond_6
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v2, "Start"
    invoke-static {v0, v2}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    .line 71
    invoke-direct {p0, p1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->initializeSurface(I)Z
    move-result p1
    const/4 v0, 0x0
    if-nez p1, :cond_15
    return v0
    .line 75
    :cond_15
    new-instance p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;
    invoke-direct {p1, v0}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;-><init>(B)V
    .line 76
    iget-boolean v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mIsRealTime:Z
    invoke-direct {p0, p1, v2}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->configureDecoder(Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;Z)Z
    move-result v2
    if-nez v2, :cond_4f
    .line 77
    invoke-direct {p0, p1, v0}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->configureDecoder(Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;Z)Z
    move-result v2
    if-eqz v2, :cond_29
    goto :goto_4f
    .line 83
    :cond_29
    iget-object v1, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->b:Lcom/tencent/liteav/videobase/videobase/h$c;
    new-instance v2, Ljava/lang/StringBuilder;
    const-string v3, "decoder config fail, message:"
    invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
    iget-object v3, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->c:Ljava/lang/String;
    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    const-string v3, " exception:"
    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget-object p1, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->d:Ljava/lang/Exception;
    .line 85
    invoke-virtual {p1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
    move-result-object p1
    invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p1
    new-array v2, v0, [Ljava/lang/Object;
    .line 83
    invoke-direct {p0, v1, p1, v2}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->handleDecoderError(Lcom/tencent/liteav/videobase/videobase/h$c;Ljava/lang/String;[Ljava/lang/Object;)V
    return v0
    .line 78
    :cond_4f
    :goto_4f
    iget-object p1, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
    iput-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
    .line 79
    iput-boolean v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mIsStarted:Z
    .line 80
    iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v0, "Start succeed"
    invoke-static {p1, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    return v1
.end method
.method public stop()V
    .registers 3
    .line 92
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    const-string v1, "stop"
    invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
    .line 93
    iget-boolean v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mIsStarted:Z
    if-nez v0, :cond_c
    return-void
    .line 96
    :cond_c
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
    invoke-direct {p0, v0}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->destroyMediaCodec(Landroid/media/MediaCodec;)V
    const/4 v0, 0x0
    .line 97
    iput-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
    .line 98
    invoke-direct {p0}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->uninitializeSurface()V
    const/4 v0, 0x0
    .line 99
    iput-boolean v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mIsStarted:Z
    return-void
.end method
.method public updateTexImage()[F
    .registers 6
    .line 152
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
    const/4 v1, 0x0
    if-nez v0, :cond_6
    return-object v1
    :cond_6
    const/16 v2, 0x10
    :try_start_8
    new-array v2, v2, [F
    .line 157
    invoke-virtual {v0}, Landroid/graphics/SurfaceTexture;->updateTexImage()V
    .line 158
    iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
    invoke-virtual {v0, v2}, Landroid/graphics/SurfaceTexture;->getTransformMatrix([F)V
    :try_end_12
    .catch Ljava/lang/Exception; {:try_start_8 .. :try_end_12} :catch_13
    return-object v2
    :catch_13
    move-exception v0
    .line 162
    iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mThrottlers:Lcom/tencent/liteav/base/b/b;
    const-string v3, "updateImage"
    invoke-virtual {v2, v3}, Lcom/tencent/liteav/base/b/b;->a(Ljava/lang/String;)Lcom/tencent/liteav/base/b/a;
    move-result-object v2
    iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
    invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
    move-result-object v0
    const-string v4, "updateTexImage exception: "
    invoke-virtual {v4, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
    move-result-object v0
    const/4 v4, 0x0
    new-array v4, v4, [Ljava/lang/Object;
    invoke-static {v2, v3, v0, v4}, Lcom/tencent/liteav/base/util/LiteavLog;->w(Lcom/tencent/liteav/base/b/a;Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    return-object v1
.end method