MediaCodecDecoder2.smali

.class public Lcom/yysdk/mobile/codec/MediaCodecDecoder2;
.super Ljava/lang/Object;
.source "SourceFile"


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;,
        Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;
    }
.end annotation


# static fields
.field static final PRE_PUTFRAME_OPT_NONE:I = 0x0

.field static final PRE_PUTFRAME_OPT_RESET:I = 0x2

.field static final PRE_PUTFRAME_OPT_SEND_EOS:I = 0x1

.field static final S_DECODE_ERR_FATAL:I = -0x15

.field static final S_DECODE_ERR_SHOULD_TRY_LATER:I = -0x14

.field static decodeGlobalLock:Ljava/lang/Object;


# instance fields
.field anchorSeq:I

.field configLock:Ljava/lang/Object;

.field curFrameLastPreOPt:I

.field decodeInfo:Landroid/media/MediaCodec$BufferInfo;

.field decodeInputBuffers:[Ljava/nio/ByteBuffer;

.field decodeLock:Ljava/lang/Object;

.field decodeOutputBuffers:[Ljava/nio/ByteBuffer;

.field decodePts:J

.field decodeSeq:J

.field decodedHeight:I

.field decodedWidth:I

.field decoder:Landroid/media/MediaCodec;

.field frameHeightCaclByCaller:I

.field frameInfoList:Ljava/util/ArrayList;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/ArrayList<",
            "Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;",
            ">;"
        }
    .end annotation
.end field

.field frameWidthCaclByCaller:I

.field gotAllLastFrames:I

.field isReorderHack:Z

.field jumpNext:Z

.field lastHeight:I

.field lastWidth:I

.field private mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

.field mConfig:[Lcom/yysdk/mobile/codec/b$a;

.field mDecoderName:Ljava/lang/String;

.field mDecoderTypeName:Ljava/lang/String;

.field private mIsPreempted:Z

.field final mLocalPlayerLog:Z

.field mProxy:Lcom/yysdk/mobile/codec/a;

.field mType:Ljava/lang/String;

.field needResetIfPpsChange:Z

.field needResetIfRefNumChange:Z

.field needResetIfSizeChange:Z

.field needResetIfSpsChange:Z

.field needSendEofIfPpsChange:Z

.field needSendEofIfRefNumChange:Z

.field needSendEofIfSpsChange:Z

.field outputFormat:Landroid/media/MediaFormat;


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

    .line 75
    new-instance v0, Ljava/lang/Object;

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

    sput-object v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeGlobalLock:Ljava/lang/Object;

    return-void
.end method

.method public constructor <init>(Lcom/yysdk/mobile/codec/a;[Lcom/yysdk/mobile/codec/b$a;Ljava/lang/String;)V
    .registers 8

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

    const/4 v0, 0x0

    .line 69
    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    .line 70
    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeInputBuffers:[Ljava/nio/ByteBuffer;

    .line 71
    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeOutputBuffers:[Ljava/nio/ByteBuffer;

    .line 72
    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    .line 73
    new-instance v1, Ljava/lang/Object;

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

    iput-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    .line 74
    new-instance v1, Ljava/lang/Object;

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

    iput-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->configLock:Ljava/lang/Object;

    const/4 v1, 0x1

    .line 76
    iput v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->gotAllLastFrames:I

    const/4 v1, -0x1

    .line 78
    iput v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedWidth:I

    .line 79
    iput v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedHeight:I

    const-wide/16 v2, 0x0

    .line 80
    iput-wide v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeSeq:J

    .line 81
    iput-wide v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodePts:J

    const/4 v2, 0x0

    .line 82
    iput v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameWidthCaclByCaller:I

    .line 83
    iput v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameHeightCaclByCaller:I

    .line 84
    iput v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastWidth:I

    .line 85
    iput v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastHeight:I

    .line 86
    iput v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->anchorSeq:I

    .line 87
    iput-boolean v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->jumpNext:Z

    .line 89
    iput-boolean v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->isReorderHack:Z

    .line 90
    iput-boolean v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needResetIfSizeChange:Z

    .line 92
    iput-boolean v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needSendEofIfRefNumChange:Z

    .line 93
    iput-boolean v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needResetIfRefNumChange:Z

    .line 95
    iput-boolean v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needSendEofIfSpsChange:Z

    .line 96
    iput-boolean v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needResetIfSpsChange:Z

    .line 98
    iput-boolean v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needSendEofIfPpsChange:Z

    .line 99
    iput-boolean v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needResetIfPpsChange:Z

    const/4 v1, 0x2

    .line 100
    iput v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->curFrameLastPreOPt:I

    .line 101
    iput-boolean v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mIsPreempted:Z

    .line 104
    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mProxy:Lcom/yysdk/mobile/codec/a;

    .line 105
    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mConfig:[Lcom/yysdk/mobile/codec/b$a;

    .line 107
    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

    .line 108
    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mType:Ljava/lang/String;

    .line 109
    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

    .line 618
    new-instance v0, Landroid/media/MediaCodec$BufferInfo;

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

    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeInfo:Landroid/media/MediaCodec$BufferInfo;

    .line 632
    new-instance v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    invoke-direct {v0}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;-><init>()V

    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    .line 115
    iput-object p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mProxy:Lcom/yysdk/mobile/codec/a;

    .line 116
    iput-object p2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mConfig:[Lcom/yysdk/mobile/codec/b$a;

    .line 117
    iput-object p3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

    const-string p1, "localplayer"

    .line 118
    invoke-virtual {p1, p3}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result p1

    iput-boolean p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    return-void
.end method

.method private PutEOS(I)I
    .registers 13

    .line 313
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    monitor-enter v0

    const/4 v1, -0x1

    .line 315
    :try_start_4
    iget-object v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    if-eqz v2, :cond_3e

    .line 316
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    const-wide/16 v2, 0x0

    invoke-virtual {v1, v2, v3}, Landroid/media/MediaCodec;->dequeueInputBuffer(J)I

    move-result v1

    if-ltz v1, :cond_2a

    .line 318
    iget-object v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeInputBuffers:[Ljava/nio/ByteBuffer;

    aget-object v2, v2, v1

    invoke-virtual {v2}, Ljava/nio/ByteBuffer;->clear()Ljava/nio/Buffer;

    .line 319
    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    const/4 v6, 0x0

    const/4 v7, 0x0

    const-wide/16 v8, 0x0

    const/4 v10, 0x4

    move v5, v1

    invoke-virtual/range {v4 .. v10}, Landroid/media/MediaCodec;->queueInputBuffer(IIIJI)V

    const/4 v2, 0x0

    .line 320
    iput v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->gotAllLastFrames:I

    .line 321
    iput p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->anchorSeq:I

    goto :goto_51

    .line 324
    :cond_2a
    iget-boolean p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz p1, :cond_36

    const-string p1, "yy-videodecoder"

    const-string v2, "get media decoder input buffer failed!"

    .line 325
    invoke-static {p1, v2}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_51

    :cond_36
    const-string p1, "yy-videodecoder"

    const-string v2, "get media decoder input buffer failed!"

    .line 327
    invoke-static {p1, v2}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_51

    .line 332
    :cond_3e
    iget-boolean p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz p1, :cond_4a

    const-string p1, "yy-videodecoder"

    const-string v2, "no media decoder instance!"

    .line 333
    invoke-static {p1, v2}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_51

    :cond_4a
    const-string p1, "yy-videodecoder"

    const-string v2, "no media decoder instance!"

    .line 335
    invoke-static {p1, v2}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    .line 338
    :goto_51
    monitor-exit v0

    return v1

    :catchall_53
    move-exception p1

    .line 339
    monitor-exit v0
    :try_end_55
    .catchall {:try_start_4 .. :try_end_55} :catchall_53

    throw p1
.end method

.method private WaitForLastFrames()I
    .registers 5

    .line 342
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    monitor-enter v0

    .line 343
    :try_start_3
    iget v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->gotAllLastFrames:I
    :try_end_5
    .catchall {:try_start_3 .. :try_end_5} :catchall_11

    if-nez v1, :cond_e

    .line 345
    :try_start_7
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    const-wide/16 v2, 0x64

    invoke-virtual {v1, v2, v3}, Ljava/lang/Object;->wait(J)V
    :try_end_e
    .catch Ljava/lang/InterruptedException; {:try_start_7 .. :try_end_e} :catch_e
    .catchall {:try_start_7 .. :try_end_e} :catchall_11

    .line 350
    :catch_e
    :cond_e
    :try_start_e
    monitor-exit v0

    const/4 v0, 0x0

    return v0

    :catchall_11
    move-exception v1

    monitor-exit v0
    :try_end_13
    .catchall {:try_start_e .. :try_end_13} :catchall_11

    throw v1
.end method

.method private fixDecodeFrameSize()V
    .registers 8

    .line 762
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mType:Ljava/lang/String;

    const-string v1, "video/avc"

    if-eq v0, v1, :cond_7

    return-void

    .line 766
    :cond_7
    iget v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameWidthCaclByCaller:I

    iget v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedWidth:I

    if-ne v0, v1, :cond_14

    iget v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameHeightCaclByCaller:I

    iget v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedHeight:I

    if-ne v0, v1, :cond_14

    return-void

    .line 771
    :cond_14
    iget v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameWidthCaclByCaller:I

    const/4 v1, 0x1

    if-le v0, v1, :cond_12f

    iget v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameHeightCaclByCaller:I

    if-gt v2, v1, :cond_1f

    goto/16 :goto_12f

    :cond_1f
    add-int/lit8 v3, v0, -0x1

    and-int/lit8 v3, v3, -0x10

    .line 775
    iget v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedWidth:I

    add-int/lit8 v5, v4, -0x1

    and-int/lit8 v5, v5, -0x10

    const-string v6, "yy-videodecoder"

    if-ne v3, v5, :cond_d2

    sub-int/2addr v2, v1

    and-int/lit8 v2, v2, -0x10

    iget v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedHeight:I

    sub-int/2addr v3, v1

    and-int/lit8 v3, v3, -0x10

    if-eq v2, v3, :cond_39

    goto/16 :goto_d2

    :cond_39
    const-string v2, "->"

    if-ge v0, v4, :cond_84

    .line 787
    iget-boolean v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    const-string v3, "fix width:"

    if-eqz v0, :cond_5d

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

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

    iget v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedWidth:I

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

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

    iget v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameWidthCaclByCaller:I

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

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

    move-result-object v0

    invoke-static {v6, v0}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_76

    .line 790
    :cond_5d
    new-instance v0, Ljava/lang/StringBuilder;

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

    iget v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedWidth:I

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

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

    iget v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameWidthCaclByCaller:I

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

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

    move-result-object v0

    invoke-static {v6, v0}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    .line 792
    :goto_76
    iget v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameWidthCaclByCaller:I

    iput v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedWidth:I

    .line 793
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget v3, v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->a:I

    iget v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedWidth:I

    add-int/2addr v3, v4

    sub-int/2addr v3, v1

    iput v3, v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->b:I

    .line 796
    :cond_84
    iget v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameHeightCaclByCaller:I

    iget v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedHeight:I

    if-ge v0, v3, :cond_d1

    .line 797
    iget-boolean v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    const-string v3, "fix height:"

    if-eqz v0, :cond_aa

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

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

    iget v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedHeight:I

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

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

    iget v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameHeightCaclByCaller:I

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

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

    move-result-object v0

    invoke-static {v6, v0}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_c3

    .line 800
    :cond_aa
    new-instance v0, Ljava/lang/StringBuilder;

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

    iget v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedHeight:I

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

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

    iget v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameHeightCaclByCaller:I

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

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

    move-result-object v0

    invoke-static {v6, v0}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    .line 802
    :goto_c3
    iget v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameHeightCaclByCaller:I

    iput v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedHeight:I

    .line 803
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget v2, v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->c:I

    iget v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedHeight:I

    add-int/2addr v2, v3

    sub-int/2addr v2, v1

    iput v2, v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->d:I

    :cond_d1
    return-void

    .line 778
    :cond_d2
    :goto_d2
    iget-boolean v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    const-string v1, " and "

    const-string v2, "mb size mismatch, there must be sth wrong! "

    const-string v3, "x"

    if-eqz v0, :cond_106

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

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

    iget v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameWidthCaclByCaller:I

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

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

    iget v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameHeightCaclByCaller:I

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

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

    iget v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedWidth:I

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

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

    iget v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedHeight:I

    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

    invoke-static {v6, v0}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    return-void

    .line 781
    :cond_106
    new-instance v0, Ljava/lang/StringBuilder;

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

    iget v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameWidthCaclByCaller:I

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

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

    iget v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameHeightCaclByCaller:I

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

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

    iget v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedWidth:I

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

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

    iget v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedHeight:I

    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

    invoke-static {v6, v0}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    :cond_12f
    :goto_12f
    return-void
.end method

.method private resetDecoder()I
    .registers 7

    .line 588
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    if-eqz v0, :cond_7

    .line 589
    invoke-direct {p0}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->safeStopAndRelease()V

    :cond_7
    const/4 v0, 0x0

    .line 592
    :try_start_8
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

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

    move-result-object v1

    iput-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    .line 593
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mType:Ljava/lang/String;

    const/16 v2, 0x500

    const/16 v3, 0x2d0

    invoke-static {v1, v2, v3}, Landroid/media/MediaFormat;->createVideoFormat(Ljava/lang/String;II)Landroid/media/MediaFormat;

    move-result-object v1

    const-string v2, "frame-rate"

    const/16 v3, 0x18

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

    .line 595
    iget-object v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    const/4 v3, 0x0

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

    .line 596
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    invoke-virtual {v1}, Landroid/media/MediaCodec;->start()V
    :try_end_2c
    .catch Ljava/lang/Exception; {:try_start_8 .. :try_end_2c} :catch_3d

    .line 609
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

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

    move-result-object v0

    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeInputBuffers:[Ljava/nio/ByteBuffer;

    .line 610
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

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

    move-result-object v0

    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeOutputBuffers:[Ljava/nio/ByteBuffer;

    return v3

    :catch_3d
    move-exception v1

    .line 598
    iget-boolean v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    const-string v3, " message: "

    const-string v4, "failed to start hardware decoder: "

    const-string v5, "yy-videodecoder"

    if-eqz v2, :cond_64

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

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

    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

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

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

    invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object v1

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

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

    move-result-object v1

    invoke-static {v5, v1}, Lcom/yysdk/mobile/localplayer/g;->g(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_7f

    .line 601
    :cond_64
    new-instance v2, Ljava/lang/StringBuilder;

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

    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

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

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

    invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object v3

    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 {v5, v2, v1}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I

    .line 603
    :goto_7f
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    if-eqz v1, :cond_88

    .line 604
    invoke-virtual {v1}, Landroid/media/MediaCodec;->release()V

    .line 605
    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    :cond_88
    const/4 v0, -0x1

    return v0
.end method

.method private safeFlush()V
    .registers 4

    .line 46
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    monitor-enter v0

    .line 49
    :try_start_3
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    invoke-virtual {v1}, Landroid/media/MediaCodec;->flush()V
    :try_end_8
    .catch Ljava/lang/IllegalStateException; {:try_start_3 .. :try_end_8} :catch_b
    .catchall {:try_start_3 .. :try_end_8} :catchall_9

    goto :goto_1e

    :catchall_9
    move-exception v1

    goto :goto_20

    .line 52
    :catch_b
    :try_start_b
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v1, :cond_17

    const-string v1, "yy-videodecoder"

    const-string v2, "flush crash"

    .line 53
    invoke-static {v1, v2}, Lcom/yysdk/mobile/localplayer/g;->f(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_1e

    :cond_17
    const-string v1, "yy-videodecoder"

    const-string v2, "flush crash"

    .line 55
    invoke-static {v1, v2}, Lcom/yysdk/mobile/util/c;->c(Ljava/lang/String;Ljava/lang/String;)I

    .line 59
    :goto_1e
    monitor-exit v0

    return-void

    :goto_20
    monitor-exit v0
    :try_end_21
    .catchall {:try_start_b .. :try_end_21} :catchall_9

    throw v1
.end method

.method private safeStopAndRelease()V
    .registers 4

    .line 24
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    monitor-enter v0

    .line 26
    :try_start_3
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    invoke-virtual {v1}, Landroid/media/MediaCodec;->stop()V
    :try_end_8
    .catch Ljava/lang/IllegalStateException; {:try_start_3 .. :try_end_8} :catch_b
    .catchall {:try_start_3 .. :try_end_8} :catchall_9

    goto :goto_1e

    :catchall_9
    move-exception v1

    goto :goto_3b

    .line 28
    :catch_b
    :try_start_b
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v1, :cond_17

    const-string v1, "yy-videodecoder"

    const-string v2, "stop crash"

    .line 29
    invoke-static {v1, v2}, Lcom/yysdk/mobile/localplayer/g;->f(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_1e

    :cond_17
    const-string v1, "yy-videodecoder"

    const-string v2, "stop crash"

    .line 31
    invoke-static {v1, v2}, Lcom/yysdk/mobile/util/c;->c(Ljava/lang/String;Ljava/lang/String;)I

    .line 35
    :goto_1e
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    invoke-virtual {v1}, Landroid/media/MediaCodec;->release()V

    const/4 v1, 0x0

    .line 36
    iput-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    .line 37
    monitor-exit v0
    :try_end_27
    .catchall {:try_start_b .. :try_end_27} :catchall_9

    .line 38
    iget-boolean v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v0, :cond_33

    const-string v0, "yy-videodecoder"

    const-string v1, "safeStopAndRelease"

    .line 39
    invoke-static {v0, v1}, Lcom/yysdk/mobile/localplayer/g;->b(Ljava/lang/String;Ljava/lang/String;)I

    return-void

    :cond_33
    const-string v0, "yy-videodecoder"

    const-string v1, "safeStopAndRelease"

    .line 41
    invoke-static {v0, v1}, Lcom/yysdk/mobile/util/c;->a(Ljava/lang/String;Ljava/lang/String;)I

    return-void

    .line 37
    :goto_3b
    :try_start_3b
    monitor-exit v0
    :try_end_3c
    .catchall {:try_start_3b .. :try_end_3c} :catchall_9

    throw v1
.end method

.method private updateOutputFrameInfo(J)V
    .registers 16

    .line 809
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameInfoList:Ljava/util/ArrayList;

    invoke-virtual {v0}, Ljava/util/ArrayList;->isEmpty()Z

    move-result v0

    const-wide/16 v1, 0x0

    const/4 v3, 0x0

    const-string v4, "yy-videodecoder"

    if-eqz v0, :cond_23

    .line 810
    iput-wide v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeSeq:J

    .line 811
    iput-wide v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodePts:J

    .line 812
    iput v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameWidthCaclByCaller:I

    .line 813
    iput v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameHeightCaclByCaller:I

    .line 814
    iget-boolean p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    const-string p2, "in fun:updateOutputFrameInfo frameInfoList isempty"

    if-eqz p1, :cond_1f

    .line 815
    invoke-static {v4, p2}, Lcom/yysdk/mobile/localplayer/g;->f(Ljava/lang/String;Ljava/lang/String;)I

    return-void

    .line 817
    :cond_1f
    invoke-static {v4, p2}, Lcom/yysdk/mobile/util/c;->c(Ljava/lang/String;Ljava/lang/String;)I

    return-void

    .line 823
    :cond_23
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameInfoList:Ljava/util/ArrayList;

    invoke-virtual {v0, v3}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;

    const/4 v5, 0x0

    .line 825
    iget-object v6, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameInfoList:Ljava/util/ArrayList;

    invoke-virtual {v6}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;

    move-result-object v6

    .line 826
    :cond_32
    :goto_32
    invoke-interface {v6}, Ljava/util/Iterator;->hasNext()Z

    move-result v7

    if-eqz v7, :cond_4f

    .line 827
    invoke-interface {v6}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v7

    check-cast v7, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;

    .line 828
    iget-wide v8, v7, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->a:J

    cmp-long v10, v8, p1

    if-nez v10, :cond_45

    move-object v5, v7

    .line 831
    :cond_45
    iget-wide v8, v7, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->b:J

    iget-wide v10, v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->b:J

    cmp-long v12, v8, v10

    if-gez v12, :cond_32

    move-object v0, v7

    goto :goto_32

    :cond_4f
    const-string v6, ", now fl size:"

    const-string v7, ", fix seq:"

    const-string v8, "getFrame from decoder, out seq:"

    if-eqz v5, :cond_e0

    .line 836
    iget-boolean v9, v5, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->c:Z

    if-eqz v9, :cond_e0

    iget-boolean v9, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->isReorderHack:Z

    if-nez v9, :cond_e0

    .line 837
    iget-wide v0, v5, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->a:J

    iput-wide v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeSeq:J

    .line 838
    iget-wide v0, v5, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->b:J

    iput-wide v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodePts:J

    .line 839
    iget v0, v5, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->d:I

    iput v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameWidthCaclByCaller:I

    .line 840
    iget v0, v5, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->e:I

    iput v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameHeightCaclByCaller:I

    .line 841
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameInfoList:Ljava/util/ArrayList;

    invoke-virtual {v0}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;

    move-result-object v0

    .line 842
    :cond_75
    :goto_75
    invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z

    move-result v1

    if-eqz v1, :cond_8d

    .line 843
    invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v1

    check-cast v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;

    .line 844
    iget-wide v1, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->a:J

    iget-wide v9, v5, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->a:J

    cmp-long v3, v1, v9

    if-gtz v3, :cond_75

    .line 845
    invoke-interface {v0}, Ljava/util/Iterator;->remove()V

    goto :goto_75

    .line 848
    :cond_8d
    invoke-static {}, Lcom/yysdk/mobile/util/c;->a()Z

    move-result v0

    if-eqz v0, :cond_b6

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

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

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

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

    iget-wide v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeSeq:J

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

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

    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameInfoList:Ljava/util/ArrayList;

    invoke-virtual {v1}, Ljava/util/ArrayList;->size()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

    invoke-static {v4, v0}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    .line 851
    :cond_b6
    invoke-static {}, Lcom/yysdk/mobile/localplayer/g;->b()Z

    move-result v0

    if-eqz v0, :cond_df

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

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

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

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

    iget-wide p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeSeq:J

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

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

    iget-object p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameInfoList:Ljava/util/ArrayList;

    invoke-virtual {p1}, Ljava/util/ArrayList;->size()I

    move-result p1

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

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

    move-result-object p1

    invoke-static {v4, p1}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    :cond_df
    return-void

    .line 857
    :cond_e0
    iget-boolean v9, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->isReorderHack:Z

    if-eqz v9, :cond_e5

    goto :goto_e6

    :cond_e5
    move-object v0, v5

    :goto_e6
    if-nez v0, :cond_128

    .line 859
    iput-wide v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeSeq:J

    .line 860
    iput-wide v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodePts:J

    .line 861
    iput v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameWidthCaclByCaller:I

    .line 862
    iput v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameHeightCaclByCaller:I

    .line 863
    iget-boolean v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    const-string v1, ", isReorderHack:"

    const-string v2, "in fun:updateOutputFrameInfo outFrameInfo is empty! seq:"

    if-eqz v0, :cond_110

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

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

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

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

    iget-boolean p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->isReorderHack:Z

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

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

    move-result-object p1

    invoke-static {v4, p1}, Lcom/yysdk/mobile/localplayer/g;->f(Ljava/lang/String;Ljava/lang/String;)I

    return-void

    .line 866
    :cond_110
    new-instance v0, Ljava/lang/StringBuilder;

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

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

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

    iget-boolean p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->isReorderHack:Z

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

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

    move-result-object p1

    invoke-static {v4, p1}, Lcom/yysdk/mobile/util/c;->c(Ljava/lang/String;Ljava/lang/String;)I

    return-void

    .line 871
    :cond_128
    iget-wide v1, v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->a:J

    iput-wide v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeSeq:J

    .line 872
    iget-wide v1, v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->b:J

    iput-wide v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodePts:J

    .line 873
    iget v1, v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->d:I

    iput v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameWidthCaclByCaller:I

    .line 874
    iget v1, v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;->e:I

    iput v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameHeightCaclByCaller:I

    .line 875
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameInfoList:Ljava/util/ArrayList;

    invoke-virtual {v1, v0}, Ljava/util/ArrayList;->remove(Ljava/lang/Object;)Z

    .line 876
    invoke-static {}, Lcom/yysdk/mobile/util/c;->a()Z

    move-result v0

    if-eqz v0, :cond_166

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

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

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

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

    iget-wide v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeSeq:J

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

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

    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameInfoList:Ljava/util/ArrayList;

    invoke-virtual {v1}, Ljava/util/ArrayList;->size()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

    invoke-static {v4, v0}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    .line 879
    :cond_166
    invoke-static {}, Lcom/yysdk/mobile/localplayer/g;->b()Z

    move-result v0

    if-eqz v0, :cond_18f

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

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

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

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

    iget-wide p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeSeq:J

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

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

    iget-object p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameInfoList:Ljava/util/ArrayList;

    invoke-virtual {p1}, Ljava/util/ArrayList;->size()I

    move-result p1

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

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

    move-result-object p1

    invoke-static {v4, p1}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    :cond_18f
    return-void
.end method


# virtual methods
.method public close()V
    .registers 3

    .line 231
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    monitor-enter v0

    .line 232
    :try_start_3
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    if-eqz v1, :cond_d

    .line 233
    invoke-direct {p0}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->safeFlush()V

    .line 234
    invoke-direct {p0}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->safeStopAndRelease()V

    .line 236
    :cond_d
    monitor-exit v0
    :try_end_e
    .catchall {:try_start_3 .. :try_end_e} :catchall_67

    .line 237
    iget-boolean v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v0, :cond_3a

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

    const-string v1, "close hardware decoder name "

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

    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

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

    const-string v1, " by "

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

    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v1, " "

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

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

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

    move-result-object v0

    const-string v1, "yy-videodecoder"

    invoke-static {v1, v0}, Lcom/yysdk/mobile/localplayer/g;->b(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_61

    .line 240
    :cond_3a
    new-instance v0, Ljava/lang/StringBuilder;

    const-string v1, "close hardware decoder name "

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

    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

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

    const-string v1, " by "

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

    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v1, " "

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

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

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

    move-result-object v0

    const-string v1, "yy-videodecoder"

    invoke-static {v1, v0}, Lcom/yysdk/mobile/util/c;->a(Ljava/lang/String;Ljava/lang/String;)I

    :goto_61
    const/4 v0, 0x0

    .line 243
    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

    .line 244
    iput-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mType:Ljava/lang/String;

    return-void

    :catchall_67
    move-exception v1

    .line 236
    :try_start_68
    monitor-exit v0
    :try_end_69
    .catchall {:try_start_68 .. :try_end_69} :catchall_67

    throw v1
.end method

.method public flush()V
    .registers 3

    .line 298
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    monitor-enter v0

    .line 299
    :try_start_3
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    if-eqz v1, :cond_f

    .line 300
    invoke-direct {p0}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->safeFlush()V

    .line 301
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameInfoList:Ljava/util/ArrayList;

    invoke-virtual {v1}, Ljava/util/ArrayList;->clear()V

    .line 303
    :cond_f
    monitor-exit v0
    :try_end_10
    .catchall {:try_start_3 .. :try_end_10} :catchall_54

    .line 304
    iget-boolean v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v0, :cond_34

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

    const-string v1, "flush hardware decoder name "

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

    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

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

    const-string v1, " by "

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

    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName: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

    const-string v1, "yy-videodecoder"

    invoke-static {v1, v0}, Lcom/yysdk/mobile/localplayer/g;->b(Ljava/lang/String;Ljava/lang/String;)I

    return-void

    .line 307
    :cond_34
    new-instance v0, Ljava/lang/StringBuilder;

    const-string v1, "flush hardware decoder name "

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

    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

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

    const-string v1, " by "

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

    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName: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

    const-string v1, "yy-videodecoder"

    invoke-static {v1, v0}, Lcom/yysdk/mobile/util/c;->a(Ljava/lang/String;Ljava/lang/String;)I

    return-void

    :catchall_54
    move-exception v1

    .line 303
    :try_start_55
    monitor-exit v0
    :try_end_56
    .catchall {:try_start_55 .. :try_end_56} :catchall_54

    throw v1
.end method

.method public getFrame()I
    .registers 16

    .line 634
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    monitor-enter v0

    .line 635
    :try_start_3
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->jumpNext:Z

    const/4 v2, 0x0

    const/4 v3, 0x1

    if-eqz v1, :cond_12

    .line 636
    iput-boolean v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->jumpNext:Z

    .line 637
    iget v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->anchorSeq:I

    int-to-long v1, v1

    iput-wide v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeSeq:J

    .line 638
    monitor-exit v0

    return v3

    .line 640
    :cond_12
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;
    :try_end_14
    .catchall {:try_start_3 .. :try_end_14} :catchall_210

    const/4 v4, -0x1

    if-eqz v1, :cond_20e

    .line 643
    :try_start_17
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeInfo:Landroid/media/MediaCodec$BufferInfo;

    const-wide/16 v6, 0x0

    invoke-virtual {v1, v5, v6, v7}, Landroid/media/MediaCodec;->dequeueOutputBuffer(Landroid/media/MediaCodec$BufferInfo;J)I

    move-result v1

    if-eq v1, v4, :cond_1f2

    const/4 v4, -0x3

    if-ne v1, v4, :cond_43

    .line 649
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v1, :cond_32

    const-string v1, "yy-videodecoder"

    const-string v3, "decoder output buffers changed"

    .line 650
    invoke-static {v1, v3}, Lcom/yysdk/mobile/localplayer/g;->b(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_39

    :cond_32
    const-string v1, "yy-videodecoder"

    const-string v3, "decoder output buffers changed"

    .line 652
    invoke-static {v1, v3}, Lcom/yysdk/mobile/util/c;->a(Ljava/lang/String;Ljava/lang/String;)I

    .line 654
    :goto_39
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

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

    move-result-object v1

    iput-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeOutputBuffers:[Ljava/nio/ByteBuffer;

    goto/16 :goto_1f0

    :cond_43
    const/4 v4, -0x2

    if-ne v1, v4, :cond_113

    .line 656
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    invoke-virtual {v1}, Landroid/media/MediaCodec;->getOutputFormat()Landroid/media/MediaFormat;

    move-result-object v1

    iput-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    .line 657
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v1, :cond_68

    const-string v1, "yy-videodecoder"

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

    const-string v5, "decoder output format changed: "

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

    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

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

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

    move-result-object v4

    invoke-static {v1, v4}, Lcom/yysdk/mobile/localplayer/g;->f(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_7d

    :cond_68
    const-string v1, "yy-videodecoder"

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

    const-string v5, "decoder output format changed: "

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

    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

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

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

    move-result-object v4

    invoke-static {v1, v4}, Lcom/yysdk/mobile/util/c;->a(Ljava/lang/String;Ljava/lang/String;)I

    .line 664
    :goto_7d
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    const-string v4, "crop-right"

    invoke-virtual {v1, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I

    move-result v1

    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    const-string v5, "crop-left"

    invoke-virtual {v4, v5}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I

    move-result v4

    sub-int/2addr v1, v4

    add-int/2addr v1, v3

    iput v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedWidth:I

    .line 665
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    const-string v4, "crop-bottom"

    invoke-virtual {v1, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I

    move-result v1

    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    const-string v5, "crop-top"

    invoke-virtual {v4, v5}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I

    move-result v4

    sub-int/2addr v1, v4

    add-int/2addr v1, v3

    iput v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodedHeight:I

    .line 667
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    const-string v4, "crop-left"

    invoke-virtual {v3, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I

    move-result v3

    iput v3, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->a:I

    .line 668
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    const-string v4, "crop-right"

    invoke-virtual {v3, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I

    move-result v3

    iput v3, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->b:I

    .line 669
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    const-string v4, "crop-top"

    invoke-virtual {v3, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I

    move-result v3

    iput v3, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->c:I

    .line 670
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    const-string v4, "crop-bottom"

    invoke-virtual {v3, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I

    move-result v3

    iput v3, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->d:I

    .line 671
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    const-string v4, "stride"

    invoke-virtual {v3, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I

    move-result v3

    iput v3, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->e:I

    .line 672
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    const-string v4, "slice-height"

    invoke-virtual {v3, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I

    move-result v3

    iput v3, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->f:I

    .line 673
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    const-string v4, "color-format"

    invoke-virtual {v3, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I

    move-result v3

    iput v3, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->g:I

    .line 674
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    const-string v4, "width"

    invoke-virtual {v3, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I

    move-result v3

    iput v3, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->h:I

    .line 675
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->outputFormat:Landroid/media/MediaFormat;

    const-string v4, "height"

    invoke-virtual {v3, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I

    move-result v3

    iput v3, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->i:I

    goto/16 :goto_1f0

    .line 679
    :cond_113
    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeInfo:Landroid/media/MediaCodec$BufferInfo;

    iget-wide v4, v4, Landroid/media/MediaCodec$BufferInfo;->presentationTimeUs:J

    const-wide/16 v6, 0x3e8

    div-long/2addr v4, v6

    .line 680
    invoke-direct {p0, v4, v5}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->updateOutputFrameInfo(J)V

    .line 681
    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeOutputBuffers:[Ljava/nio/ByteBuffer;

    aget-object v4, v4, v1

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

    .line 682
    invoke-direct {p0}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->fixDecodeFrameSize()V

    .line 683
    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget v9, v4, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->a:I

    .line 684
    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget v10, v4, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->b:I

    .line 685
    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget v11, v4, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->c:I

    .line 686
    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget v12, v4, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->d:I

    .line 687
    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget v4, v4, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->e:I

    .line 688
    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget v5, v5, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->f:I

    .line 689
    iget-object v6, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget v6, v6, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->g:I

    .line 691
    sget-object v7, Landroid/os/Build;->MODEL:Ljava/lang/String;

    const-string v8, "MI 3"

    invoke-virtual {v7, v8}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z

    move-result v7

    if-eqz v7, :cond_16e

    sub-int v7, v10, v9

    add-int/2addr v7, v3

    sub-int v8, v12, v11

    add-int/2addr v8, v3

    sub-int/2addr v7, v3

    and-int/lit8 v7, v7, -0x10

    add-int/lit8 v7, v7, 0x10

    sub-int/2addr v8, v3

    and-int/lit8 v8, v8, -0x20

    add-int/lit8 v8, v8, 0x20

    if-eq v4, v7, :cond_164

    const/16 v13, 0x2d0

    if-ne v4, v13, :cond_164

    move v4, v7

    :cond_164
    if-eq v8, v5, :cond_16b

    const/16 v7, 0x500

    if-ne v5, v7, :cond_16b

    move v5, v8

    :cond_16b
    :goto_16b
    move v13, v4

    move v14, v5

    goto :goto_181

    .line 703
    :cond_16e
    sget-object v7, Landroid/os/Build;->MODEL:Ljava/lang/String;

    const-string v8, "MI NOTE Pro"

    invoke-virtual {v7, v8}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z

    move-result v7

    if-eqz v7, :cond_16b

    .line 704
    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget v4, v4, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->h:I

    .line 705
    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mBufferedFormatValues:Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;

    iget v5, v5, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$a;->i:I

    goto :goto_16b

    .line 707
    :goto_181
    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeInfo:Landroid/media/MediaCodec$BufferInfo;

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

    if-nez v4, :cond_19c

    .line 708
    iget-boolean v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v4, :cond_193

    const-string v4, "yy-videodecoder"

    const-string v5, "Empty output"

    .line 709
    invoke-static {v4, v5}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_19a

    :cond_193
    const-string v4, "yy-videodecoder"

    const-string v5, "Empty output"

    .line 711
    invoke-static {v4, v5}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    :goto_19a
    const/4 v4, 0x0

    goto :goto_1ae

    .line 715
    :cond_19c
    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mProxy:Lcom/yysdk/mobile/codec/a;

    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeOutputBuffers:[Ljava/nio/ByteBuffer;

    aget-object v7, v4, v1

    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeOutputBuffers:[Ljava/nio/ByteBuffer;

    aget-object v4, v4, v1

    .line 716
    invoke-virtual {v4}, Ljava/nio/ByteBuffer;->position()I

    move-result v8

    .line 715
    invoke-virtual/range {v5 .. v14}, Lcom/yysdk/mobile/codec/a;->codec_convert2Yuv420p(ILjava/nio/ByteBuffer;IIIIIII)I

    move-result v4

    .line 720
    :goto_1ae
    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    invoke-virtual {v5, v1, v2}, Landroid/media/MediaCodec;->releaseOutputBuffer(IZ)V

    .line 722
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeInfo:Landroid/media/MediaCodec$BufferInfo;

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

    const/4 v2, 0x4

    and-int/2addr v1, v2

    if-ne v1, v2, :cond_1ef

    .line 723
    iput v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->gotAllLastFrames:I

    .line 724
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    invoke-virtual {v1}, Ljava/lang/Object;->notifyAll()V

    .line 725
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeInfo:Landroid/media/MediaCodec$BufferInfo;

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

    if-nez v1, :cond_1dc

    .line 727
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v1, :cond_1d4

    const-string v1, "yy-videodecoder"

    const-string v2, "Got pure EOS"

    .line 728
    invoke-static {v1, v2}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_1ef

    :cond_1d4
    const-string v1, "yy-videodecoder"

    const-string v2, "Got pure EOS"

    .line 730
    invoke-static {v1, v2}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_1ef

    .line 734
    :cond_1dc
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v1, :cond_1e8

    const-string v1, "yy-videodecoder"

    const-string v2, "Got loaded EOS"

    .line 735
    invoke-static {v1, v2}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_1ef

    :cond_1e8
    const-string v1, "yy-videodecoder"

    const-string v2, "Got loaded EOS"

    .line 737
    invoke-static {v1, v2}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_1ef
    .catch Ljava/lang/IllegalStateException; {:try_start_17 .. :try_end_1ef} :catch_1f4
    .catchall {:try_start_17 .. :try_end_1ef} :catchall_210

    :cond_1ef
    :goto_1ef
    move v2, v4

    .line 742
    :goto_1f0
    :try_start_1f0
    monitor-exit v0

    return v2

    .line 744
    :cond_1f2
    monitor-exit v0

    return v4

    .line 748
    :catch_1f4
    invoke-direct {p0}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->safeStopAndRelease()V

    .line 749
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v1, :cond_203

    const-string v1, "yy-videodecoder"

    const-string v2, "got IllegalStateException when getFrame "

    .line 750
    invoke-static {v1, v2}, Lcom/yysdk/mobile/localplayer/g;->b(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_20a

    :cond_203
    const-string v1, "yy-videodecoder"

    const-string v2, "got IllegalStateException when getFrame "

    .line 752
    invoke-static {v1, v2}, Lcom/yysdk/mobile/util/c;->a(Ljava/lang/String;Ljava/lang/String;)I

    :goto_20a
    const/16 v1, -0x15

    .line 754
    monitor-exit v0

    return v1

    .line 757
    :cond_20e
    monitor-exit v0

    return v4

    :catchall_210
    move-exception v1

    .line 758
    monitor-exit v0
    :try_end_212
    .catchall {:try_start_1f0 .. :try_end_212} :catchall_210

    goto :goto_214

    :goto_213
    throw v1

    :goto_214
    goto :goto_213
.end method

.method public isDecoderValid()Z
    .registers 3

    .line 225
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    monitor-enter v0

    .line 226
    :try_start_3
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    if-eqz v1, :cond_9

    const/4 v1, 0x1

    goto :goto_a

    :cond_9
    const/4 v1, 0x0

    :goto_a
    monitor-exit v0

    return v1

    :catchall_c
    move-exception v1

    .line 227
    monitor-exit v0
    :try_end_e
    .catchall {:try_start_3 .. :try_end_e} :catchall_c

    throw v1
.end method

.method public open(I)I
    .registers 9

    .line 130
    invoke-static {p1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v0

    const-string v1, "open "

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

    move-result-object v0

    const-string v1, "yy-videodecoder"

    invoke-static {v1, v0}, Lcom/yysdk/mobile/localplayer/g;->f(Ljava/lang/String;Ljava/lang/String;)I

    .line 132
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->configLock:Ljava/lang/Object;

    monitor-enter v0

    .line 133
    :try_start_12
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mConfig:[Lcom/yysdk/mobile/codec/b$a;

    .line 134
    monitor-exit v0
    :try_end_15
    .catchall {:try_start_12 .. :try_end_15} :catchall_20f

    .line 135
    iget-object v2, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    monitor-enter v2

    const/4 v0, 0x0

    .line 136
    :try_start_19
    iput-boolean v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->jumpNext:Z

    const/4 v3, 0x1

    .line 137
    iput v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->gotAllLastFrames:I

    const/4 v4, -0x1

    .line 138
    iput v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastWidth:I

    .line 139
    iput v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastHeight:I

    if-eqz v1, :cond_1d5

    .line 141
    array-length v5, v1

    if-nez v5, :cond_2a

    goto/16 :goto_1d5

    .line 151
    :cond_2a
    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mProxy:Lcom/yysdk/mobile/codec/a;

    invoke-virtual {v5}, Lcom/yysdk/mobile/codec/a;->getHWDecoderCfg()I

    move-result v5

    and-int/lit16 v5, v5, 0x80

    if-eqz v5, :cond_36

    const/4 v5, 0x1

    goto :goto_37

    :cond_36
    const/4 v5, 0x0

    :goto_37
    iput-boolean v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->isReorderHack:Z

    .line 152
    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mProxy:Lcom/yysdk/mobile/codec/a;

    invoke-virtual {v5}, Lcom/yysdk/mobile/codec/a;->getHWDecoderCfg()I

    move-result v5

    and-int/lit16 v5, v5, 0x100

    if-eqz v5, :cond_45

    const/4 v5, 0x1

    goto :goto_46

    :cond_45
    const/4 v5, 0x0

    :goto_46
    iput-boolean v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needResetIfSizeChange:Z

    .line 154
    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mProxy:Lcom/yysdk/mobile/codec/a;

    invoke-virtual {v5}, Lcom/yysdk/mobile/codec/a;->getHWDecoderCfg()I

    move-result v5

    and-int/lit16 v5, v5, 0x1000

    if-eqz v5, :cond_54

    const/4 v5, 0x1

    goto :goto_55

    :cond_54
    const/4 v5, 0x0

    :goto_55
    iput-boolean v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needSendEofIfRefNumChange:Z

    .line 155
    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mProxy:Lcom/yysdk/mobile/codec/a;

    invoke-virtual {v5}, Lcom/yysdk/mobile/codec/a;->getHWDecoderCfg()I

    move-result v5

    and-int/lit16 v5, v5, 0x2000

    if-eqz v5, :cond_63

    const/4 v5, 0x1

    goto :goto_64

    :cond_63
    const/4 v5, 0x0

    :goto_64
    iput-boolean v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needResetIfRefNumChange:Z

    .line 157
    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mProxy:Lcom/yysdk/mobile/codec/a;

    invoke-virtual {v5}, Lcom/yysdk/mobile/codec/a;->getHWDecoderCfg()I

    move-result v5

    and-int/lit16 v5, v5, 0x4000

    if-eqz v5, :cond_72

    const/4 v5, 0x1

    goto :goto_73

    :cond_72
    const/4 v5, 0x0

    :goto_73
    iput-boolean v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needSendEofIfSpsChange:Z

    .line 158
    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mProxy:Lcom/yysdk/mobile/codec/a;

    invoke-virtual {v5}, Lcom/yysdk/mobile/codec/a;->getHWDecoderCfg()I

    move-result v5

    const v6, 0x8000

    and-int/2addr v5, v6

    if-eqz v5, :cond_83

    const/4 v5, 0x1

    goto :goto_84

    :cond_83
    const/4 v5, 0x0

    :goto_84
    iput-boolean v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needResetIfSpsChange:Z

    .line 160
    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mProxy:Lcom/yysdk/mobile/codec/a;

    invoke-virtual {v5}, Lcom/yysdk/mobile/codec/a;->getHWDecoderCfg()I

    move-result v5

    const/high16 v6, 0x10000000

    and-int/2addr v5, v6

    if-eqz v5, :cond_93

    const/4 v5, 0x1

    goto :goto_94

    :cond_93
    const/4 v5, 0x0

    :goto_94
    iput-boolean v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needSendEofIfPpsChange:Z

    .line 161
    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mProxy:Lcom/yysdk/mobile/codec/a;

    invoke-virtual {v5}, Lcom/yysdk/mobile/codec/a;->getHWDecoderCfg()I

    move-result v5

    const/high16 v6, 0x20000000

    and-int/2addr v5, v6

    if-eqz v5, :cond_a2

    goto :goto_a3

    :cond_a2
    const/4 v3, 0x0

    :goto_a3
    iput-boolean v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needResetIfPpsChange:Z

    const/4 v3, 0x2

    .line 163
    iput v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->curFrameLastPreOPt:I

    if-ne p1, v3, :cond_af

    const-string p1, "video/avc"

    .line 167
    iput-object p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mType:Ljava/lang/String;

    goto :goto_b6

    :cond_af
    const/4 v3, 0x5

    if-ne p1, v3, :cond_1d3

    const-string p1, "video/hevc"

    .line 169
    iput-object p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mType:Ljava/lang/String;

    :goto_b6
    const/4 p1, 0x0

    .line 174
    :goto_b7
    array-length v3, v1

    if-ge p1, v3, :cond_cf

    .line 175
    aget-object v3, v1, p1

    iget-object v3, v3, Lcom/yysdk/mobile/codec/b$a;->c:Ljava/lang/String;

    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mType:Ljava/lang/String;

    invoke-virtual {v3, v5}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v3

    if-eqz v3, :cond_cc

    .line 176
    aget-object v3, v1, p1

    iget-object v3, v3, Lcom/yysdk/mobile/codec/b$a;->d:Ljava/lang/String;

    iput-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

    :cond_cc
    add-int/lit8 p1, p1, 0x1

    goto :goto_b7

    .line 180
    :cond_cf
    iget-boolean p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz p1, :cond_e9

    const-string p1, "yy-videodecoder"

    .line 181
    new-instance v1, Ljava/lang/StringBuilder;

    const-string v3, "hardware decoder name "

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

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

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

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

    move-result-object v1

    invoke-static {p1, v1}, Lcom/yysdk/mobile/localplayer/g;->b(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_fe

    :cond_e9
    const-string p1, "yy-videodecoder"

    .line 183
    new-instance v1, Ljava/lang/StringBuilder;

    const-string v3, "hardware decoder name "

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

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

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

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

    move-result-object v1

    invoke-static {p1, v1}, Lcom/yysdk/mobile/util/c;->a(Ljava/lang/String;Ljava/lang/String;)I

    .line 185
    :goto_fe
    iget-object p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

    if-nez p1, :cond_104

    .line 186
    monitor-exit v2
    :try_end_103
    .catchall {:try_start_19 .. :try_end_103} :catchall_20c

    return v4

    :cond_104
    const/4 p1, 0x0

    .line 190
    :try_start_105
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

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

    move-result-object v1

    iput-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    .line 191
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mType:Ljava/lang/String;

    const/16 v3, 0x500

    const/16 v5, 0x2d0

    invoke-static {v1, v3, v5}, Landroid/media/MediaFormat;->createVideoFormat(Ljava/lang/String;II)Landroid/media/MediaFormat;

    move-result-object v1

    const-string v3, "frame-rate"

    const/16 v5, 0x18

    .line 192
    invoke-virtual {v1, v3, v5}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V

    .line 193
    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

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

    .line 194
    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    invoke-virtual {v1}, Landroid/media/MediaCodec;->start()V
    :try_end_128
    .catch Ljava/lang/Exception; {:try_start_105 .. :try_end_128} :catch_17e
    .catchall {:try_start_105 .. :try_end_128} :catchall_20c

    .line 210
    :try_start_128
    iget-object p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

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

    move-result-object p1

    iput-object p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeInputBuffers:[Ljava/nio/ByteBuffer;

    .line 211
    iget-object p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

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

    move-result-object p1

    iput-object p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeOutputBuffers:[Ljava/nio/ByteBuffer;

    .line 212
    new-instance p1, Ljava/util/ArrayList;

    const/16 v1, 0xd

    invoke-direct {p1, v1}, Ljava/util/ArrayList;-><init>(I)V

    iput-object p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameInfoList:Ljava/util/ArrayList;

    .line 215
    iget-boolean p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz p1, :cond_161

    const-string p1, "yy-videodecoder"

    .line 216
    new-instance v1, Ljava/lang/StringBuilder;

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

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v3, " open hardware decoder succeed! this:"

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

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

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

    move-result-object v1

    invoke-static {p1, v1}, Lcom/yysdk/mobile/localplayer/g;->b(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_17c

    :cond_161
    const-string p1, "yy-videodecoder"

    .line 218
    new-instance v1, Ljava/lang/StringBuilder;

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

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v3, " open hardware decoder succeed! this:"

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

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

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

    move-result-object v1

    invoke-static {p1, v1}, Lcom/yysdk/mobile/util/c;->a(Ljava/lang/String;Ljava/lang/String;)I

    .line 220
    :goto_17c
    monitor-exit v2

    return v0

    :catch_17e
    move-exception v0

    .line 196
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v1, :cond_1a5

    const-string v1, "yy-videodecoder"

    .line 197
    new-instance v3, Ljava/lang/StringBuilder;

    const-string v5, "failed to start hardware decoder: "

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

    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

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

    const-string v5, " message: "

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

    invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object v0

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

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

    move-result-object v0

    invoke-static {v1, v0}, Lcom/yysdk/mobile/localplayer/g;->g(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_1c6

    :cond_1a5
    const-string v1, "yy-videodecoder"

    .line 199
    new-instance v3, Ljava/lang/StringBuilder;

    const-string v5, "failed to start hardware decoder: "

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

    iget-object v5, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderName:Ljava/lang/String;

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

    const-string v5, " message: "

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

    invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object v5

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

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

    move-result-object v3

    invoke-static {v1, v3, v0}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I

    .line 201
    :goto_1c6
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    if-eqz v0, :cond_1d1

    .line 202
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    invoke-virtual {v0}, Landroid/media/MediaCodec;->release()V

    .line 203
    iput-object p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    .line 205
    :cond_1d1
    monitor-exit v2

    return v4

    .line 171
    :cond_1d3
    monitor-exit v2

    return v4

    .line 142
    :cond_1d5
    :goto_1d5
    iget-boolean p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz p1, :cond_1f2

    const-string p1, "yy-videodecoder"

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

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

    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v1, " mConfig is null!"

    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

    invoke-static {p1, v0}, Lcom/yysdk/mobile/localplayer/g;->f(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_20a

    :cond_1f2
    const-string p1, "yy-videodecoder"

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

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

    iget-object v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v1, " mConfig is null!"

    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

    invoke-static {p1, v0}, Lcom/yysdk/mobile/util/c;->c(Ljava/lang/String;Ljava/lang/String;)I

    .line 147
    :goto_20a
    monitor-exit v2

    return v4

    :catchall_20c
    move-exception p1

    .line 221
    monitor-exit v2
    :try_end_20e
    .catchall {:try_start_128 .. :try_end_20e} :catchall_20c

    throw p1

    :catchall_20f
    move-exception p1

    .line 134
    :try_start_210
    monitor-exit v0
    :try_end_211
    .catchall {:try_start_210 .. :try_end_211} :catchall_20f

    goto :goto_213

    :goto_212
    throw p1

    :goto_213
    goto :goto_212
.end method

.method public putFrame(IJIIII)I
    .registers 32

    move-object/from16 v1, p0

    move/from16 v0, p1

    move-wide/from16 v10, p2

    move/from16 v12, p4

    move/from16 v2, p5

    move/from16 v3, p6

    .line 357
    iget v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastWidth:I

    .line 358
    iget v5, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastHeight:I

    const/4 v6, 0x2

    const/4 v14, 0x1

    if-lez v2, :cond_86

    if-lez v3, :cond_86

    .line 360
    invoke-static {}, Lcom/yysdk/mobile/util/c;->a()Z

    move-result v7

    if-eqz v7, :cond_3f

    .line 361
    new-instance v7, Ljava/lang/StringBuilder;

    const-string v8, "new size "

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

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

    const-string v8, "x"

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

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

    const-string v8, " seq "

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

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

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

    move-result-object v7

    const-string v8, "yy-videodecoder"

    invoke-static {v8, v7}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    .line 363
    :cond_3f
    invoke-static {}, Lcom/yysdk/mobile/localplayer/g;->b()Z

    move-result v7

    if-eqz v7, :cond_68

    .line 364
    new-instance v7, Ljava/lang/StringBuilder;

    const-string v8, "new size "

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

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

    const-string v8, "x"

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

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

    const-string v8, " seq "

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

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

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

    move-result-object v7

    const-string v8, "yy-videodecoder"

    invoke-static {v8, v7}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    .line 366
    :cond_68
    iget v7, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastWidth:I

    if-ne v2, v7, :cond_70

    iget v7, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastHeight:I

    if-eq v3, v7, :cond_86

    .line 367
    :cond_70
    iget v7, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastWidth:I

    if-lez v7, :cond_80

    iget v7, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastHeight:I

    if-lez v7, :cond_80

    .line 369
    iget-boolean v7, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needResetIfSizeChange:Z

    if-eqz v7, :cond_7e

    const/4 v7, 0x2

    goto :goto_81

    :cond_7e
    const/4 v7, 0x1

    goto :goto_81

    :cond_80
    const/4 v7, 0x0

    .line 373
    :goto_81
    iput v2, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastWidth:I

    .line 374
    iput v3, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastHeight:I

    goto :goto_87

    :cond_86
    const/4 v7, 0x0

    :goto_87
    and-int/lit8 v8, p7, 0x1

    if-eqz v8, :cond_8d

    const/4 v8, 0x1

    goto :goto_8e

    :cond_8d
    const/4 v8, 0x0

    :goto_8e
    shr-int/lit8 v9, p7, 0x1

    and-int/2addr v9, v14

    if-eqz v9, :cond_95

    const/4 v9, 0x1

    goto :goto_96

    :cond_95
    const/4 v9, 0x0

    :goto_96
    shr-int/lit8 v15, p7, 0x2

    and-int/2addr v15, v14

    if-eqz v15, :cond_9d

    const/4 v15, 0x1

    goto :goto_9e

    :cond_9d
    const/4 v15, 0x0

    .line 380
    :goto_9e
    iget-boolean v13, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needSendEofIfRefNumChange:Z

    if-eqz v13, :cond_a4

    if-nez v8, :cond_b0

    :cond_a4
    iget-boolean v13, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needSendEofIfSpsChange:Z

    if-eqz v13, :cond_aa

    if-nez v9, :cond_b0

    :cond_aa
    iget-boolean v13, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needSendEofIfPpsChange:Z

    if-eqz v13, :cond_b3

    if-eqz v15, :cond_b3

    :cond_b0
    if-gtz v7, :cond_b3

    const/4 v7, 0x1

    .line 388
    :cond_b3
    iget-boolean v13, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needResetIfRefNumChange:Z

    if-eqz v13, :cond_b9

    if-nez v8, :cond_c5

    :cond_b9
    iget-boolean v8, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needResetIfSpsChange:Z

    if-eqz v8, :cond_bf

    if-nez v9, :cond_c5

    :cond_bf
    iget-boolean v8, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->needResetIfPpsChange:Z

    if-eqz v8, :cond_c8

    if-eqz v15, :cond_c8

    :cond_c5
    if-le v6, v7, :cond_c8

    const/4 v7, 0x2

    :cond_c8
    if-lez v7, :cond_217

    .line 396
    iget v9, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->curFrameLastPreOPt:I

    if-ge v9, v7, :cond_217

    if-nez v9, :cond_1a7

    .line 398
    iget-boolean v9, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v9, :cond_dc

    const-string v9, "yy-videodecoder"

    const-string v15, "Putting EOS"

    .line 399
    invoke-static {v9, v15}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_e3

    :cond_dc
    const-string v9, "yy-videodecoder"

    const-string v15, "Putting EOS"

    .line 401
    invoke-static {v9, v15}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    .line 403
    :goto_e3
    invoke-direct {v1, v12}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->PutEOS(I)I

    move-result v9

    if-ltz v9, :cond_192

    .line 404
    iget-boolean v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v4, :cond_f5

    const-string v4, "yy-videodecoder"

    const-string v5, "Putting EOS done"

    .line 405
    invoke-static {v4, v5}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_fc

    :cond_f5
    const-string v4, "yy-videodecoder"

    const-string v5, "Putting EOS done"

    .line 407
    invoke-static {v4, v5}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    .line 409
    :goto_fc
    invoke-direct/range {p0 .. p0}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->WaitForLastFrames()I

    .line 410
    iget-boolean v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v4, :cond_10b

    const-string v4, "yy-videodecoder"

    const-string v5, "Waiting EOS done"

    .line 411
    invoke-static {v4, v5}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_112

    :cond_10b
    const-string v4, "yy-videodecoder"

    const-string v5, "Waiting EOS done"

    .line 413
    invoke-static {v4, v5}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    .line 415
    :goto_112
    iput v14, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->curFrameLastPreOPt:I

    .line 416
    iget-object v9, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    monitor-enter v9

    .line 417
    :try_start_117
    iget-object v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    if-eqz v4, :cond_18c

    .line 418
    invoke-direct/range {p0 .. p0}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->safeFlush()V

    .line 419
    iput v14, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->gotAllLastFrames:I

    .line 420
    iget-object v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameInfoList:Ljava/util/ArrayList;

    invoke-virtual {v4}, Ljava/util/ArrayList;->clear()V

    .line 421
    iput-boolean v14, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->jumpNext:Z

    .line 422
    iget-boolean v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v4, :cond_133

    const-string v4, "yy-videodecoder"

    const-string v5, "flush done"

    .line 423
    invoke-static {v4, v5}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_13a

    :cond_133
    const-string v4, "yy-videodecoder"

    const-string v5, "flush done"

    .line 425
    invoke-static {v4, v5}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    :goto_13a
    if-ne v7, v6, :cond_18c

    .line 429
    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v4

    .line 430
    invoke-direct/range {p0 .. p0}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->resetDecoder()I

    move-result v7

    .line 431
    iput v6, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->curFrameLastPreOPt:I

    .line 432
    iget-boolean v6, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v6, :cond_16b

    const-string v6, "yy-videodecoder"

    .line 433
    new-instance v15, Ljava/lang/StringBuilder;

    const-string v8, "reset decoder return code:"

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

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

    const-string v7, ", timecost:"

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

    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v7

    sub-long/2addr v7, v4

    invoke-virtual {v15, v7, v8}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

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

    move-result-object v4

    invoke-static {v6, v4}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_18c

    :cond_16b
    const-string v6, "yy-videodecoder"

    .line 435
    new-instance v8, Ljava/lang/StringBuilder;

    const-string v15, "reset decoder return code:"

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

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

    const-string v7, ", timecost:"

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

    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v16

    sub-long v4, v16, v4

    invoke-virtual {v8, v4, v5}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

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

    move-result-object v4

    invoke-static {v6, v4}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    .line 439
    :cond_18c
    :goto_18c
    monitor-exit v9

    goto/16 :goto_217

    :catchall_18f
    move-exception v0

    monitor-exit v9
    :try_end_191
    .catchall {:try_start_117 .. :try_end_191} :catchall_18f

    throw v0

    .line 442
    :cond_192
    iput v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastWidth:I

    .line 443
    iput v5, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->lastHeight:I

    .line 445
    iget-object v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    monitor-enter v4

    .line 446
    :try_start_199
    iget-object v0, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    if-nez v0, :cond_1a0

    const/16 v13, -0x15

    goto :goto_1a2

    :cond_1a0
    const/16 v13, -0x14

    .line 449
    :goto_1a2
    monitor-exit v4

    return v13

    :catchall_1a4
    move-exception v0

    monitor-exit v4
    :try_end_1a6
    .catchall {:try_start_199 .. :try_end_1a6} :catchall_1a4

    throw v0

    :cond_1a7
    if-ne v9, v14, :cond_204

    .line 454
    iget-object v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    monitor-enter v4

    if-ne v7, v6, :cond_1ff

    .line 456
    :try_start_1ae
    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v7

    .line 457
    invoke-direct/range {p0 .. p0}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->resetDecoder()I

    move-result v5

    .line 458
    iput v6, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->curFrameLastPreOPt:I

    .line 459
    iget-boolean v6, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v6, :cond_1de

    const-string v6, "yy-videodecoder"

    .line 460
    new-instance v9, Ljava/lang/StringBuilder;

    const-string v15, "reset decoder return code:"

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

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

    const-string v5, ", timecost:"

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

    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v16

    sub-long v7, v16, v7

    invoke-virtual {v9, v7, v8}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

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

    move-result-object v5

    invoke-static {v6, v5}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_1ff

    :cond_1de
    const-string v6, "yy-videodecoder"

    .line 462
    new-instance v9, Ljava/lang/StringBuilder;

    const-string v15, "reset decoder return code:"

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

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

    const-string v5, ", timecost:"

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

    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v16

    sub-long v7, v16, v7

    invoke-virtual {v9, v7, v8}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

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

    move-result-object v5

    invoke-static {v6, v5}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    .line 465
    :cond_1ff
    :goto_1ff
    monitor-exit v4

    goto :goto_217

    :catchall_201
    move-exception v0

    monitor-exit v4
    :try_end_203
    .catchall {:try_start_1ae .. :try_end_203} :catchall_201

    throw v0

    .line 468
    :cond_204
    iget-boolean v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v4, :cond_210

    const-string v4, "yy-videodecoder"

    const-string v5, "should not go here"

    .line 469
    invoke-static {v4, v5}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_217

    :cond_210
    const-string v4, "yy-videodecoder"

    const-string v5, "should not go here"

    .line 471
    invoke-static {v4, v5}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    .line 511
    :cond_217
    :goto_217
    iget-object v15, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeLock:Ljava/lang/Object;

    monitor-enter v15

    .line 514
    :try_start_21a
    iget-object v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;
    :try_end_21c
    .catchall {:try_start_21a .. :try_end_21c} :catchall_35a

    if-eqz v4, :cond_343

    .line 516
    :try_start_21e
    iget-object v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    const-wide/16 v5, 0x0

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

    move-result v9

    if-ltz v9, :cond_315

    .line 518
    iget-object v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeInputBuffers:[Ljava/nio/ByteBuffer;

    aget-object v4, v4, v9

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

    .line 519
    iget-object v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mProxy:Lcom/yysdk/mobile/codec/a;

    iget-object v5, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeInputBuffers:[Ljava/nio/ByteBuffer;

    aget-object v5, v5, v9

    invoke-virtual {v4, v5}, Lcom/yysdk/mobile/codec/a;->codec_hardware_decoder_put_frame(Ljava/nio/ByteBuffer;)I

    move-result v8

    .line 520
    iget-object v4, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeInputBuffers:[Ljava/nio/ByteBuffer;

    aget-object v4, v4, v9

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

    .line 525
    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v5

    int-to-long v13, v12

    const-wide/16 v17, 0x3e8

    mul-long v20, v13, v17

    .line 528
    new-instance v7, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;

    const/4 v4, 0x1

    if-ne v0, v4, :cond_251

    const/16 v17, 0x1

    goto :goto_253

    :cond_251
    const/16 v17, 0x0

    :goto_253
    if-lez v2, :cond_256

    goto :goto_257

    :cond_256
    neg-int v2, v2

    :goto_257
    move/from16 v18, v2

    if-lez v3, :cond_25e

    move/from16 v19, v3

    goto :goto_261

    :cond_25e
    neg-int v2, v3

    move/from16 v19, v2

    :goto_261
    move-object v2, v7

    move-wide v3, v13

    move-wide v13, v5

    move-wide/from16 v5, p2

    move-object v0, v7

    move/from16 v7, v17

    move/from16 v22, v8

    move/from16 v8, v18

    move/from16 v23, v9

    move/from16 v9, v19

    invoke-direct/range {v2 .. v9}, Lcom/yysdk/mobile/codec/MediaCodecDecoder2$b;-><init>(JJZII)V

    .line 530
    iget-object v2, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->frameInfoList:Ljava/util/ArrayList;

    invoke-virtual {v2, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z

    .line 531
    invoke-static {}, Lcom/yysdk/mobile/util/c;->a()Z

    move-result v0

    if-eqz v0, :cond_2bd

    const-string v0, "yy-videodecoder"

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

    const-string v3, "putFrame to decoder ts:"

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

    invoke-virtual {v2, v13, v14}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v3, " seq:"

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

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

    const-string v3, " ts:"

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

    invoke-virtual {v2, v10, v11}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v3, " is key?"

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

    move/from16 v3, p1

    const/4 v4, 0x1

    if-ne v3, v4, :cond_2a7

    const/4 v4, 0x1

    goto :goto_2a8

    :cond_2a7
    const/4 v4, 0x0

    :goto_2a8
    invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;

    const-string v4, ", decodeInputBufferIndex="

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

    move/from16 v4, v23

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

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

    move-result-object v2

    invoke-static {v0, v2}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_2c1

    :cond_2bd
    move/from16 v3, p1

    move/from16 v4, v23

    .line 539
    :goto_2c1
    invoke-static {}, Lcom/yysdk/mobile/localplayer/g;->b()Z

    move-result v0

    if-eqz v0, :cond_300

    const-string v0, "yy-videodecoder"

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

    const-string v5, "putFrame to decoder ts:"

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

    invoke-virtual {v2, v13, v14}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v5, " seq:"

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

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

    const-string v5, " ts:"

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

    invoke-virtual {v2, v10, v11}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v5, " is key?"

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

    const/4 v5, 0x1

    if-ne v3, v5, :cond_2ed

    const/4 v14, 0x1

    goto :goto_2ee

    :cond_2ed
    const/4 v14, 0x0

    :goto_2ee
    invoke-virtual {v2, v14}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;

    const-string v3, ", decodeInputBufferIndex="

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

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

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

    move-result-object v2

    invoke-static {v0, v2}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I

    .line 547
    :cond_300
    iget-object v0, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decoder:Landroid/media/MediaCodec;

    const/16 v18, 0x0

    const/4 v2, 0x0

    move-object/from16 v16, v0

    move/from16 v17, v4

    move/from16 v19, v22

    move/from16 v22, v2

    invoke-virtual/range {v16 .. v22}, Landroid/media/MediaCodec;->queueInputBuffer(IIIJI)V

    const/4 v0, 0x0

    .line 554
    iput v0, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->curFrameLastPreOPt:I

    move v13, v4

    goto :goto_358

    :cond_315
    move v4, v9

    .line 556
    invoke-static {}, Lcom/yysdk/mobile/util/c;->a()Z

    move-result v0

    if-eqz v0, :cond_32b

    const-string v0, "yy-videodecoder"

    const-string v2, "get media decoder input buffer failed! decodeInputBufferIndex:"

    .line 557
    invoke-static {v4}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v3

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

    move-result-object v2

    invoke-static {v0, v2}, Lcom/yysdk/mobile/util/c;->b(Ljava/lang/String;Ljava/lang/String;)I

    .line 561
    :cond_32b
    invoke-static {}, Lcom/yysdk/mobile/localplayer/g;->b()Z

    move-result v0

    if-eqz v0, :cond_340

    const-string v0, "yy-videodecoder"

    const-string v2, "get media decoder input buffer failed! decodeInputBufferIndex:"

    .line 562
    invoke-static {v4}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v3

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

    move-result-object v2

    invoke-static {v0, v2}, Lcom/yysdk/mobile/localplayer/g;->c(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_340
    .catch Ljava/lang/IllegalStateException; {:try_start_21e .. :try_end_340} :catch_356
    .catchall {:try_start_21e .. :try_end_340} :catchall_35a

    :cond_340
    const/16 v13, -0x14

    goto :goto_358

    .line 575
    :cond_343
    :try_start_343
    iget-boolean v0, v1, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v0, :cond_34f

    const-string v0, "yy-videodecoder"

    const-string v2, "no media decoder instance!"

    .line 576
    invoke-static {v0, v2}, Lcom/yysdk/mobile/localplayer/g;->f(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_356

    :cond_34f
    const-string v0, "yy-videodecoder"

    const-string v2, "no media decoder instance!"

    .line 578
    invoke-static {v0, v2}, Lcom/yysdk/mobile/util/c;->c(Ljava/lang/String;Ljava/lang/String;)I

    :catch_356
    :goto_356
    const/16 v13, -0x15

    .line 582
    :goto_358
    monitor-exit v15

    return v13

    :catchall_35a
    move-exception v0

    .line 583
    monitor-exit v15
    :try_end_35c
    .catchall {:try_start_343 .. :try_end_35c} :catchall_35a

    throw v0
.end method

.method public release()V
    .registers 5

    .line 277
    sget-object v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeGlobalLock:Ljava/lang/Object;

    monitor-enter v0

    .line 278
    :try_start_3
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mIsPreempted:Z

    if-eqz v1, :cond_49

    const/4 v1, 0x0

    .line 279
    invoke-static {v1}, Lcom/yysdk/mobile/b/a;->a(Z)V

    .line 280
    iput-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mIsPreempted:Z

    .line 281
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v1, :cond_2d

    const-string v1, "yy-videodecoder"

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

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

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v3, " release hardware decoder preemption this:"

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

    invoke-virtual {v2, p0}, 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}, Lcom/yysdk/mobile/localplayer/g;->b(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_84

    :cond_2d
    const-string v1, "yy-videodecoder"

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

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

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v3, " release hardware decoder preemption this:"

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

    invoke-virtual {v2, p0}, 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}, Lcom/yysdk/mobile/util/c;->a(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_84

    .line 287
    :cond_49
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v1, :cond_69

    const-string v1, "yy-videodecoder"

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

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

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v3, " release hardware decoder error!!! it requests failed before. this:"

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

    invoke-virtual {v2, p0}, 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}, Lcom/yysdk/mobile/localplayer/g;->f(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_84

    :cond_69
    const-string v1, "yy-videodecoder"

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

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

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v3, " release hardware decoder error!!! it requests failed before. this:"

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

    invoke-virtual {v2, p0}, 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}, Lcom/yysdk/mobile/util/c;->c(Ljava/lang/String;Ljava/lang/String;)I

    .line 293
    :goto_84
    monitor-exit v0

    return-void

    :catchall_86
    move-exception v1

    monitor-exit v0
    :try_end_88
    .catchall {:try_start_3 .. :try_end_88} :catchall_86

    throw v1
.end method

.method public request()I
    .registers 6

    .line 248
    sget-object v0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->decodeGlobalLock:Ljava/lang/Object;

    monitor-enter v0

    .line 249
    :try_start_3
    invoke-static {}, Lcom/yysdk/mobile/b/a;->a()Z

    move-result v1

    const/4 v2, -0x1

    if-eqz v1, :cond_4b

    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mIsPreempted:Z

    if-nez v1, :cond_4b

    .line 250
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v1, :cond_2e

    const-string v1, "yy-videodecoder"

    .line 251
    new-instance v3, Ljava/lang/StringBuilder;

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

    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v4, " request hardware decoder failed! this:"

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

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

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

    move-result-object v3

    invoke-static {v1, v3}, Lcom/yysdk/mobile/localplayer/g;->f(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_49

    :cond_2e
    const-string v1, "yy-videodecoder"

    .line 253
    new-instance v3, Ljava/lang/StringBuilder;

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

    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v4, " request hardware decoder failed! this:"

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

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

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

    move-result-object v3

    invoke-static {v1, v3}, Lcom/yysdk/mobile/util/c;->c(Ljava/lang/String;Ljava/lang/String;)I

    .line 255
    :goto_49
    monitor-exit v0

    return v2

    .line 257
    :cond_4b
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mIsPreempted:Z

    if-eqz v1, :cond_86

    .line 258
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v1, :cond_6c

    const-string v1, "yy-videodecoder"

    .line 259
    new-instance v3, Ljava/lang/StringBuilder;

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

    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v4, " last time no release!! request failed!tttttttttttttt"

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

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

    move-result-object v3

    invoke-static {v1, v3}, Lcom/yysdk/mobile/localplayer/g;->f(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_84

    :cond_6c
    const-string v1, "yy-videodecoder"

    .line 261
    new-instance v3, Ljava/lang/StringBuilder;

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

    iget-object v4, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v4, " last time no release!! request failed!"

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

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

    move-result-object v3

    invoke-static {v1, v3}, Lcom/yysdk/mobile/util/c;->c(Ljava/lang/String;Ljava/lang/String;)I

    .line 263
    :goto_84
    monitor-exit v0

    return v2

    :cond_86
    const/4 v1, 0x1

    .line 265
    invoke-static {v1}, Lcom/yysdk/mobile/b/a;->a(Z)V

    .line 266
    iput-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mIsPreempted:Z

    .line 267
    iget-boolean v1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mLocalPlayerLog:Z

    if-eqz v1, :cond_ac

    const-string v1, "yy-videodecoder"

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

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

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v3, " request hardware decoder succeed! this:"

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

    invoke-virtual {v2, p0}, 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}, Lcom/yysdk/mobile/localplayer/g;->b(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_c7

    :cond_ac
    const-string v1, "yy-videodecoder"

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

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

    iget-object v3, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mDecoderTypeName:Ljava/lang/String;

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

    const-string v3, " request hardware decoder succeed! this:"

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

    invoke-virtual {v2, p0}, 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}, Lcom/yysdk/mobile/util/c;->a(Ljava/lang/String;Ljava/lang/String;)I

    :goto_c7
    const/4 v1, 0x0

    .line 272
    monitor-exit v0

    return v1

    :catchall_ca
    move-exception v1

    .line 273
    monitor-exit v0
    :try_end_cc
    .catchall {:try_start_3 .. :try_end_cc} :catchall_ca

    throw v1
.end method

.method public setConfig([Lcom/yysdk/mobile/codec/b$a;)V
    .registers 3

    .line 122
    iget-object v0, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->configLock:Ljava/lang/Object;

    monitor-enter v0

    .line 123
    :try_start_3
    iput-object p1, p0, Lcom/yysdk/mobile/codec/MediaCodecDecoder2;->mConfig:[Lcom/yysdk/mobile/codec/b$a;

    .line 124
    monitor-exit v0

    return-void

    :catchall_7
    move-exception p1

    monitor-exit v0
    :try_end_9
    .catchall {:try_start_3 .. :try_end_9} :catchall_7

    throw p1
.end method

.method public stopDecodeThread()V
    .registers 1

    return-void
.end method