HardwareVideoDecoder.smali 
.class Lio/agora/base/internal/video/HardwareVideoDecoder;
.super Ljava/lang/Object;
.source "HardwareVideoDecoder.java"
# interfaces
.implements Lio/agora/base/internal/video/VideoDecoder;
.implements Lio/agora/base/internal/video/VideoSink;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;,
        Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;,
        Lio/agora/base/internal/video/HardwareVideoDecoder$FrameInfo;
    }
.end annotation
# static fields
.field private static final DEBUG:Z = false
.field private static final DEQUEUE_INPUT_TIMEOUT_US:I = 0x7a120
.field private static final DEQUEUE_OUTPUT_BUFFER_TIMEOUT_US:I = 0x186a0
.field private static final MAX_DECODE_TIME_MS:I = 0x7d0
.field private static final MAX_DEQUEUED_OUTPUTBUFFERS:I = 0x3
.field private static final MAX_TEXTURE_BUFFER_COUNT:I = 0x10
.field private static final MEDIA_CODEC_RELEASE_TIMEOUT_MS:I = 0x1388
.field private static final MEDIA_FORMAT_KEY_CROP_BOTTOM:Ljava/lang/String; = "crop-bottom"
.field private static final MEDIA_FORMAT_KEY_CROP_LEFT:Ljava/lang/String; = "crop-left"
.field private static final MEDIA_FORMAT_KEY_CROP_RIGHT:Ljava/lang/String; = "crop-right"
.field private static final MEDIA_FORMAT_KEY_CROP_TOP:Ljava/lang/String; = "crop-top"
.field private static final MEDIA_FORMAT_KEY_SLICE_HEIGHT:Ljava/lang/String; = "slice-height"
.field private static final MEDIA_FORMAT_KEY_STRIDE:Ljava/lang/String; = "stride"
.field private static final TAG:Ljava/lang/String; = "HardwareVideoDecoder"
# instance fields
.field private callback:Lio/agora/base/internal/video/VideoDecoder$Callback;
.field private codec:Lio/agora/base/internal/video/MediaCodecWrapper;
.field private final codecName:Ljava/lang/String;
.field private codecSpecificInfoMap:Ljava/util/Map;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Map<",
            "Ljava/lang/Long;",
            "Lio/agora/base/internal/video/CodecSpecificInfo;",
            ">;"
        }
    .end annotation
.end field
.field private final codecType:Lio/agora/base/internal/video/VideoCodecType;
.field private colorFormat:I
.field private customConfigJson:Ljava/lang/String;
.field private final decodeTimeStamps:Ljava/util/Queue;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Queue<",
            "Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;",
            ">;"
        }
    .end annotation
.end field
.field private final dequeuedSurfaceOutputBuffers:Ljava/util/Queue;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Queue<",
            "Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;",
            ">;"
        }
    .end annotation
.end field
.field private final dimensionLock:Ljava/lang/Object;
.field private directSurface:Landroid/view/Surface;
.field private final frameInfos:Ljava/util/concurrent/BlockingDeque;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/BlockingDeque<",
            "Lio/agora/base/internal/video/HardwareVideoDecoder$FrameInfo;",
            ">;"
        }
    .end annotation
.end field
.field private hasDecodedFirstFrame:Z
.field private height:I
.field private isHisiCodec:Z
.field private keyFrameRequired:Z
.field private final mediaCodecWrapperFactory:Lio/agora/base/internal/video/MediaCodecWrapperFactory;
.field private outputThread:Ljava/lang/Thread;
.field private outputThreadChecker:Lio/agora/base/internal/ThreadUtils$ThreadChecker;
.field private final params:Ljava/util/Map;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Map<",
            "Ljava/lang/String;",
            "Ljava/lang/String;",
            ">;"
        }
    .end annotation
.end field
.field private proxyThreadHandler:Landroid/os/Handler;
.field private renderedTextureMetadata:Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;
.field private volatile running:Z
.field private final sharedContext:Lio/agora/base/internal/video/EglBase$Context;
.field private volatile shutdownException:Ljava/lang/Exception;
.field private sliceHeight:I
.field private stride:I
.field private surface:Landroid/view/Surface;
.field private surfaceTextureHelper:Lio/agora/base/internal/video/SurfaceTextureHelper;
.field private final textureMetadataLock:Ljava/lang/Object;
.field private width:I
# direct methods
.method constructor <init>(Lio/agora/base/internal/video/MediaCodecWrapperFactory;Ljava/lang/String;Lio/agora/base/internal/video/VideoCodecType;Ljava/util/Map;ILio/agora/base/internal/video/EglBase$Context;Landroid/view/Surface;)V
    .registers 11
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Lio/agora/base/internal/video/MediaCodecWrapperFactory;",
            "Ljava/lang/String;",
            "Lio/agora/base/internal/video/VideoCodecType;",
            "Ljava/util/Map<",
            "Ljava/lang/String;",
            "Ljava/lang/String;",
            ">;I",
            "Lio/agora/base/internal/video/EglBase$Context;",
            "Landroid/view/Surface;",
            ")V"
        }
    .end annotation
    .line 188
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V
    .line 106
    new-instance v0, Ljava/util/concurrent/ConcurrentLinkedQueue;
    invoke-direct {v0}, Ljava/util/concurrent/ConcurrentLinkedQueue;-><init>()V
    iput-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->decodeTimeStamps:Ljava/util/Queue;
    const/4 v0, 0x0
    .line 118
    iput-boolean v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->running:Z
    const/4 v1, 0x0
    .line 119
    iput-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->shutdownException:Ljava/lang/Exception;
    .line 123
    new-instance v2, Ljava/lang/Object;
    invoke-direct {v2}, Ljava/lang/Object;-><init>()V
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->dimensionLock:Ljava/lang/Object;
    .line 129
    iput-boolean v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->isHisiCodec:Z
    .line 142
    iput-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surface:Landroid/view/Surface;
    .line 166
    new-instance v0, Ljava/lang/Object;
    invoke-direct {v0}, Ljava/lang/Object;-><init>()V
    iput-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->textureMetadataLock:Ljava/lang/Object;
    .line 170
    new-instance v0, Ljava/util/LinkedList;
    invoke-direct {v0}, Ljava/util/LinkedList;-><init>()V
    iput-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->dequeuedSurfaceOutputBuffers:Ljava/util/Queue;
    .line 180
    iput-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    .line 183
    new-instance v0, Ljava/util/HashMap;
    invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
    iput-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecSpecificInfoMap:Ljava/util/Map;
    .line 189
    invoke-direct {p0, p5}, Lio/agora/base/internal/video/HardwareVideoDecoder;->isSupportedColorFormat(I)Z
    move-result v0
    if-eqz v0, :cond_5d
    .line 193
    sget-object v0, Lio/agora/base/internal/video/VideoCodecType;->H265:Lio/agora/base/internal/video/VideoCodecType;
    .line 194
    invoke-virtual {v0}, Lio/agora/base/internal/video/VideoCodecType;->name()Ljava/lang/String;
    move-result-object v0
    sget-object v1, Lio/agora/base/internal/video/VideoCodecProfile;->HEVCMain10HDR10:Lio/agora/base/internal/video/VideoCodecProfile;
    invoke-virtual {v1}, Lio/agora/base/internal/video/VideoCodecProfile;->name()Ljava/lang/String;
    move-result-object v1
    .line 193
    invoke-static {v0, v1}, Lio/agora/base/internal/video/VideoDecoderUtils;->isSupportHwDecoderByTypeAndProfile(Ljava/lang/String;Ljava/lang/String;)Z
    .line 196
    iput-object p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->mediaCodecWrapperFactory:Lio/agora/base/internal/video/MediaCodecWrapperFactory;
    .line 197
    iput-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecName:Ljava/lang/String;
    .line 198
    iput-object p3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecType:Lio/agora/base/internal/video/VideoCodecType;
    .line 199
    iput p5, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->colorFormat:I
    .line 200
    iput-object p4, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->params:Ljava/util/Map;
    .line 201
    iput-object p6, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->sharedContext:Lio/agora/base/internal/video/EglBase$Context;
    .line 202
    iput-object p7, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->directSurface:Landroid/view/Surface;
    .line 203
    new-instance p1, Ljava/util/concurrent/LinkedBlockingDeque;
    invoke-direct {p1}, Ljava/util/concurrent/LinkedBlockingDeque;-><init>()V
    iput-object p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->frameInfos:Ljava/util/concurrent/BlockingDeque;
    return-void
    .line 190
    :cond_5d
    new-instance p1, Ljava/lang/IllegalArgumentException;
    new-instance p2, Ljava/lang/StringBuilder;
    invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
    const-string p3, "Unsupported color format: "
    invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {p2, p5}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p2
    invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
    throw p1
.end method
.method static synthetic access$000(Lio/agora/base/internal/video/HardwareVideoDecoder;)Lio/agora/base/internal/video/MediaCodecWrapper;
    .registers 1
    .line 50
    iget-object p0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    return-object p0
.end method
.method static synthetic access$002(Lio/agora/base/internal/video/HardwareVideoDecoder;Lio/agora/base/internal/video/MediaCodecWrapper;)Lio/agora/base/internal/video/MediaCodecWrapper;
    .registers 2
    .line 50
    iput-object p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    return-object p1
.end method
.method static synthetic access$100(Lio/agora/base/internal/video/HardwareVideoDecoder;)Ljava/lang/String;
    .registers 1
    .line 50
    iget-object p0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecName:Ljava/lang/String;
    return-object p0
.end method
.method static synthetic access$1000(Lio/agora/base/internal/video/HardwareVideoDecoder;)Z
    .registers 1
    .line 50
    iget-boolean p0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->keyFrameRequired:Z
    return p0
.end method
.method static synthetic access$1002(Lio/agora/base/internal/video/HardwareVideoDecoder;Z)Z
    .registers 2
    .line 50
    iput-boolean p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->keyFrameRequired:Z
    return p1
.end method
.method static synthetic access$1102(Lio/agora/base/internal/video/HardwareVideoDecoder;Lio/agora/base/internal/ThreadUtils$ThreadChecker;)Lio/agora/base/internal/ThreadUtils$ThreadChecker;
    .registers 2
    .line 50
    iput-object p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->outputThreadChecker:Lio/agora/base/internal/ThreadUtils$ThreadChecker;
    return-object p1
.end method
.method static synthetic access$1200(Lio/agora/base/internal/video/HardwareVideoDecoder;)Z
    .registers 1
    .line 50
    iget-boolean p0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->running:Z
    return p0
.end method
.method static synthetic access$1300(Lio/agora/base/internal/video/HardwareVideoDecoder;)V
    .registers 1
    .line 50
    invoke-direct {p0}, Lio/agora/base/internal/video/HardwareVideoDecoder;->releaseCodecOnOutputThread()V
    return-void
.end method
.method static synthetic access$200(Lio/agora/base/internal/video/HardwareVideoDecoder;)Lio/agora/base/internal/video/MediaCodecWrapperFactory;
    .registers 1
    .line 50
    iget-object p0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->mediaCodecWrapperFactory:Lio/agora/base/internal/video/MediaCodecWrapperFactory;
    return-object p0
.end method
.method static synthetic access$300(Lio/agora/base/internal/video/HardwareVideoDecoder;)Landroid/view/Surface;
    .registers 1
    .line 50
    iget-object p0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surface:Landroid/view/Surface;
    return-object p0
.end method
.method static synthetic access$400(Lio/agora/base/internal/video/HardwareVideoDecoder;)Ljava/lang/String;
    .registers 1
    .line 50
    iget-object p0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->customConfigJson:Ljava/lang/String;
    return-object p0
.end method
.method static synthetic access$500(Lio/agora/base/internal/video/HardwareVideoDecoder;)Ljava/util/concurrent/BlockingDeque;
    .registers 1
    .line 50
    iget-object p0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->frameInfos:Ljava/util/concurrent/BlockingDeque;
    return-object p0
.end method
.method static synthetic access$600(Lio/agora/base/internal/video/HardwareVideoDecoder;)Ljava/util/Map;
    .registers 1
    .line 50
    iget-object p0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecSpecificInfoMap:Ljava/util/Map;
    return-object p0
.end method
.method static synthetic access$700(Lio/agora/base/internal/video/HardwareVideoDecoder;)Ljava/util/Queue;
    .registers 1
    .line 50
    iget-object p0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->decodeTimeStamps:Ljava/util/Queue;
    return-object p0
.end method
.method static synthetic access$900(Ljava/lang/String;)V
    .registers 1
    .line 50
    invoke-static {p0}, Lio/agora/base/internal/video/HardwareVideoDecoder;->debug_log(Ljava/lang/String;)V
    return-void
.end method
.method private copyI420Buffer(Ljava/nio/ByteBuffer;IIII)Lio/agora/base/VideoFrame$Buffer;
    .registers 24
    move-object/from16 v0, p1
    move/from16 v3, p2
    move/from16 v6, p4
    move/from16 v7, p5
    .line 855
    rem-int/lit8 v1, v3, 0x2
    if-nez v1, :cond_bd
    add-int/lit8 v1, v6, 0x1
    .line 865
    div-int/lit8 v9, v1, 0x2
    .line 866
    rem-int/lit8 v10, p3, 0x2
    if-nez v10, :cond_19
    add-int/lit8 v1, v7, 0x1
    div-int/lit8 v1, v1, 0x2
    goto :goto_1b
    :cond_19
    div-int/lit8 v1, v7, 0x2
    :goto_1b
    move v11, v1
    .line 868
    div-int/lit8 v12, v3, 0x2
    mul-int v1, v3, v7
    const/4 v2, 0x0
    add-int/2addr v1, v2
    mul-int v4, v3, p3
    add-int/lit8 v13, v4, 0x0
    mul-int v4, v12, v11
    add-int v8, v13, v4
    mul-int v5, v12, p3
    .line 874
    div-int/lit8 v5, v5, 0x2
    add-int v14, v13, v5
    add-int v15, v14, v4
    move-object/from16 v5, p0
    .line 877
    invoke-virtual {v5, v6, v7}, Lio/agora/base/internal/video/HardwareVideoDecoder;->allocateI420Buffer(II)Lio/agora/base/VideoFrame$I420Buffer;
    move-result-object v16
    .line 879
    invoke-virtual {v0, v1}, Ljava/nio/ByteBuffer;->limit(I)Ljava/nio/Buffer;
    .line 880
    invoke-virtual {v0, v2}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
    .line 882
    invoke-virtual/range {p1 .. p1}, Ljava/nio/ByteBuffer;->slice()Ljava/nio/ByteBuffer;
    move-result-object v2
    invoke-interface/range {v16 .. v16}, Lio/agora/base/VideoFrame$I420Buffer;->getDataY()Ljava/nio/ByteBuffer;
    move-result-object v4
    invoke-interface/range {v16 .. v16}, Lio/agora/base/VideoFrame$I420Buffer;->getStrideY()I
    move-result v17
    move-object/from16 v1, p0
    move/from16 v3, p2
    move/from16 v5, v17
    move/from16 v6, p4
    move/from16 v7, p5
    .line 881
    invoke-virtual/range {v1 .. v7}, Lio/agora/base/internal/video/HardwareVideoDecoder;->copyPlane(Ljava/nio/ByteBuffer;ILjava/nio/ByteBuffer;III)V
    .line 884
    invoke-virtual {v0, v8}, Ljava/nio/ByteBuffer;->limit(I)Ljava/nio/Buffer;
    .line 885
    invoke-virtual {v0, v13}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
    .line 886
    invoke-virtual/range {p1 .. p1}, Ljava/nio/ByteBuffer;->slice()Ljava/nio/ByteBuffer;
    move-result-object v3
    invoke-interface/range {v16 .. v16}, Lio/agora/base/VideoFrame$I420Buffer;->getDataU()Ljava/nio/ByteBuffer;
    move-result-object v5
    invoke-interface/range {v16 .. v16}, Lio/agora/base/VideoFrame$I420Buffer;->getStrideU()I
    move-result v6
    move-object/from16 v2, p0
    move v4, v12
    move v7, v9
    move v8, v11
    invoke-virtual/range {v2 .. v8}, Lio/agora/base/internal/video/HardwareVideoDecoder;->copyPlane(Ljava/nio/ByteBuffer;ILjava/nio/ByteBuffer;III)V
    const/4 v1, 0x1
    if-ne v10, v1, :cond_8a
    add-int/lit8 v2, v11, -0x1
    mul-int/2addr v2, v12
    add-int/2addr v13, v2
    .line 889
    invoke-virtual {v0, v13}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
    .line 891
    invoke-interface/range {v16 .. v16}, Lio/agora/base/VideoFrame$I420Buffer;->getDataU()Ljava/nio/ByteBuffer;
    move-result-object v2
    .line 892
    invoke-interface/range {v16 .. v16}, Lio/agora/base/VideoFrame$I420Buffer;->getStrideU()I
    move-result v3
    mul-int/2addr v3, v11
    invoke-virtual {v2, v3}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
    .line 893
    invoke-virtual {v2, v0}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
    .line 896
    :cond_8a
    invoke-virtual {v0, v15}, Ljava/nio/ByteBuffer;->limit(I)Ljava/nio/Buffer;
    .line 897
    invoke-virtual {v0, v14}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
    .line 898
    invoke-virtual/range {p1 .. p1}, Ljava/nio/ByteBuffer;->slice()Ljava/nio/ByteBuffer;
    move-result-object v3
    invoke-interface/range {v16 .. v16}, Lio/agora/base/VideoFrame$I420Buffer;->getDataV()Ljava/nio/ByteBuffer;
    move-result-object v5
    invoke-interface/range {v16 .. v16}, Lio/agora/base/VideoFrame$I420Buffer;->getStrideV()I
    move-result v6
    move-object/from16 v2, p0
    move v4, v12
    move v7, v9
    move v8, v11
    invoke-virtual/range {v2 .. v8}, Lio/agora/base/internal/video/HardwareVideoDecoder;->copyPlane(Ljava/nio/ByteBuffer;ILjava/nio/ByteBuffer;III)V
    if-ne v10, v1, :cond_bc
    add-int/lit8 v1, v11, -0x1
    mul-int/2addr v12, v1
    add-int/2addr v14, v12
    .line 901
    invoke-virtual {v0, v14}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
    .line 903
    invoke-interface/range {v16 .. v16}, Lio/agora/base/VideoFrame$I420Buffer;->getDataV()Ljava/nio/ByteBuffer;
    move-result-object v1
    .line 904
    invoke-interface/range {v16 .. v16}, Lio/agora/base/VideoFrame$I420Buffer;->getStrideV()I
    move-result v2
    mul-int/2addr v2, v11
    invoke-virtual {v1, v2}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
    .line 905
    invoke-virtual {v1, v0}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
    :cond_bc
    return-object v16
    .line 856
    :cond_bd
    new-instance v0, Ljava/lang/AssertionError;
    new-instance v1, Ljava/lang/StringBuilder;
    invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
    const-string v2, "Stride is not divisible by two: "
    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v1
    invoke-direct {v0, v1}, Ljava/lang/AssertionError;-><init>(Ljava/lang/Object;)V
    throw v0
.end method
.method private copyNV12ToI420Buffer(Ljava/nio/ByteBuffer;IIII)Lio/agora/base/VideoFrame$Buffer;
    .registers 14
    .line 849
    new-instance v7, Lio/agora/base/NV12Buffer;
    const/4 v6, 0x0
    move-object v0, v7
    move v1, p4
    move v2, p5
    move v3, p2
    move v4, p3
    move-object v5, p1
    invoke-direct/range {v0 .. v6}, Lio/agora/base/NV12Buffer;-><init>(IIIILjava/nio/ByteBuffer;Ljava/lang/Runnable;)V
    .line 850
    invoke-virtual {v7}, Lio/agora/base/NV12Buffer;->toI420()Lio/agora/base/VideoFrame$I420Buffer;
    move-result-object p1
    return-object p1
.end method
.method private copyNV21ToI420Buffer(Ljava/nio/ByteBuffer;IIII)Lio/agora/base/VideoFrame$Buffer;
    .registers 14
    .line 842
    new-instance v7, Lio/agora/base/NV21Buffer;
    const/4 v6, 0x0
    move-object v0, v7
    move v1, p4
    move v2, p5
    move v3, p2
    move v4, p3
    move-object v5, p1
    invoke-direct/range {v0 .. v6}, Lio/agora/base/NV21Buffer;-><init>(IIIILjava/nio/ByteBuffer;Ljava/lang/Runnable;)V
    .line 843
    invoke-virtual {v7}, Lio/agora/base/NV21Buffer;->toI420()Lio/agora/base/VideoFrame$I420Buffer;
    move-result-object p1
    return-object p1
.end method
.method private createOutputThread()Ljava/lang/Thread;
    .registers 3
    .line 587
    new-instance v0, Lio/agora/base/internal/video/HardwareVideoDecoder$4;
    const-string v1, "HardwareVideoDecoder.outputThread"
    invoke-direct {v0, p0, v1}, Lio/agora/base/internal/video/HardwareVideoDecoder$4;-><init>(Lio/agora/base/internal/video/HardwareVideoDecoder;Ljava/lang/String;)V
    return-object v0
.end method
.method private static final debug_log(Ljava/lang/String;)V
    .registers 1
    return-void
.end method
.method private deliverByteFrame(ILandroid/media/MediaCodec$BufferInfo;ILjava/lang/Integer;)V
    .registers 16
    .line 761
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->dimensionLock:Ljava/lang/Object;
    monitor-enter v0
    .line 762
    :try_start_3
    iget v5, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->width:I
    .line 763
    iget v6, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->height:I
    .line 764
    iget v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->stride:I
    .line 765
    iget v4, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->sliceHeight:I
    .line 766
    monitor-exit v0
    :try_end_c
    .catchall {:try_start_3 .. :try_end_c} :catchall_158
    .line 770
    iget v0, p2, Landroid/media/MediaCodec$BufferInfo;->size:I
    mul-int v2, v5, v6
    mul-int/lit8 v2, v2, 0x3
    div-int/lit8 v2, v2, 0x2
    if-ge v0, v2, :cond_2f
    const-string p1, "HardwareVideoDecoder"
    .line 771
    new-instance p3, Ljava/lang/StringBuilder;
    invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
    const-string p4, "Insufficient output buffer size: "
    invoke-virtual {p3, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget p2, p2, Landroid/media/MediaCodec$BufferInfo;->size:I
    invoke-virtual {p3, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p2
    invoke-static {p1, p2}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
    return-void
    .line 775
    :cond_2f
    iget v0, p2, Landroid/media/MediaCodec$BufferInfo;->size:I
    mul-int v2, v1, v6
    mul-int/lit8 v2, v2, 0x3
    div-int/lit8 v2, v2, 0x2
    if-ge v0, v2, :cond_46
    if-ne v4, v6, :cond_46
    if-le v1, v5, :cond_46
    .line 779
    iget v0, p2, Landroid/media/MediaCodec$BufferInfo;->size:I
    mul-int/lit8 v0, v0, 0x2
    mul-int/lit8 v1, v6, 0x3
    div-int/2addr v0, v1
    move v3, v0
    goto :goto_47
    :cond_46
    move v3, v1
    :goto_47
    const/4 v0, 0x0
    .line 785
    :try_start_48
    iget-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    invoke-interface {v1}, Lio/agora/base/internal/video/MediaCodecWrapper;->getOutputBuffers()[Ljava/nio/ByteBuffer;
    move-result-object v1
    aget-object v1, v1, p1
    :try_end_50
    .catch Ljava/lang/IllegalStateException; {:try_start_48 .. :try_end_50} :catch_51
    goto :goto_5a
    :catch_51
    move-exception v1
    const-string v2, "HardwareVideoDecoder"
    const-string v7, "getOutputBuffers failed"
    .line 787
    invoke-static {v2, v7, v1}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    move-object v1, v0
    .line 790
    :goto_5a
    iget v2, p2, Landroid/media/MediaCodec$BufferInfo;->offset:I
    invoke-virtual {v1, v2}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
    .line 791
    iget v2, p2, Landroid/media/MediaCodec$BufferInfo;->offset:I
    iget v7, p2, Landroid/media/MediaCodec$BufferInfo;->size:I
    add-int/2addr v2, v7
    invoke-virtual {v1, v2}, Ljava/nio/ByteBuffer;->limit(I)Ljava/nio/Buffer;
    .line 792
    invoke-virtual {v1}, Ljava/nio/ByteBuffer;->slice()Ljava/nio/ByteBuffer;
    move-result-object v2
    .line 793
    iget v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->colorFormat:I
    const/16 v7, 0x13
    if-ne v1, v7, :cond_77
    move-object v1, p0
    .line 794
    invoke-direct/range {v1 .. v6}, Lio/agora/base/internal/video/HardwareVideoDecoder;->copyI420Buffer(Ljava/nio/ByteBuffer;IIII)Lio/agora/base/VideoFrame$Buffer;
    move-result-object v1
    goto :goto_8a
    .line 795
    :cond_77
    iget-boolean v7, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->isHisiCodec:Z
    if-eqz v7, :cond_85
    const/16 v7, 0x27
    if-ne v1, v7, :cond_85
    move-object v1, p0
    .line 797
    invoke-direct/range {v1 .. v6}, Lio/agora/base/internal/video/HardwareVideoDecoder;->copyNV21ToI420Buffer(Ljava/nio/ByteBuffer;IIII)Lio/agora/base/VideoFrame$Buffer;
    move-result-object v1
    goto :goto_8a
    :cond_85
    move-object v1, p0
    .line 800
    invoke-direct/range {v1 .. v6}, Lio/agora/base/internal/video/HardwareVideoDecoder;->copyNV12ToI420Buffer(Ljava/nio/ByteBuffer;IIII)Lio/agora/base/VideoFrame$Buffer;
    move-result-object v1
    .line 804
    :goto_8a
    :try_start_8a
    iget-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    const/4 v3, 0x0
    invoke-interface {v2, p1, v3}, Lio/agora/base/internal/video/MediaCodecWrapper;->releaseOutputBuffer(IZ)V
    :try_end_90
    .catch Ljava/lang/IllegalStateException; {:try_start_8a .. :try_end_90} :catch_9a
    .catch Ljava/lang/Exception; {:try_start_8a .. :try_end_90} :catch_91
    goto :goto_a2
    :catch_91
    move-exception p1
    const-string v2, "HardwareVideoDecoder"
    const-string v3, "deliverByteFrame error"
    .line 808
    invoke-static {v2, v3, p1}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    goto :goto_a2
    :catch_9a
    move-exception p1
    const-string v2, "HardwareVideoDecoder"
    const-string v3, "deliverByteFrame failed"
    .line 806
    invoke-static {v2, v3, p1}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .line 811
    :goto_a2
    iget-wide v2, p2, Landroid/media/MediaCodec$BufferInfo;->presentationTimeUs:J
    const-wide/16 v4, 0x3e8
    mul-long/2addr v2, v4
    .line 812
    new-instance p1, Lio/agora/base/VideoFrame;
    invoke-direct {p1, v1, p3, v2, v3}, Lio/agora/base/VideoFrame;-><init>(Lio/agora/base/VideoFrame$Buffer;IJ)V
    .line 813
    iget-object p3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecSpecificInfoMap:Ljava/util/Map;
    iget-wide v1, p2, Landroid/media/MediaCodec$BufferInfo;->presentationTimeUs:J
    .line 814
    invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
    move-result-object v1
    invoke-interface {p3, v1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
    move-result-object p3
    move-object v10, p3
    check-cast v10, Lio/agora/base/internal/video/CodecSpecificInfo;
    .line 818
    iget-object p3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->decodeTimeStamps:Ljava/util/Queue;
    invoke-interface {p3}, Ljava/util/Queue;->size()I
    move-result v9
    .line 819
    :goto_c1
    iget-object p3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->decodeTimeStamps:Ljava/util/Queue;
    invoke-interface {p3}, Ljava/util/Queue;->isEmpty()Z
    move-result p3
    if-nez p3, :cond_103
    iget-object p3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->decodeTimeStamps:Ljava/util/Queue;
    invoke-interface {p3}, Ljava/util/Queue;->poll()Ljava/lang/Object;
    move-result-object p3
    move-object v0, p3
    check-cast v0, Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;
    if-eqz v0, :cond_103
    .line 820
    # getter for: Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;->presentationTimeStampUs:J
    invoke-static {v0}, Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;->access$800(Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;)J
    move-result-wide v1
    iget-wide v3, p2, Landroid/media/MediaCodec$BufferInfo;->presentationTimeUs:J
    cmp-long p3, v1, v3
    if-eqz p3, :cond_103
    const-string p3, "HardwareVideoDecoder"
    .line 821
    new-instance v1, Ljava/lang/StringBuilder;
    invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
    const-string v2, "decodeTimeStamps remove: "
    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    .line 822
    # getter for: Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;->presentationTimeStampUs:J
    invoke-static {v0}, Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;->access$800(Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;)J
    move-result-wide v2
    invoke-virtual {v1, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
    const-string v2, " , cannot find presentationTimeUs: "
    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget-wide v2, p2, Landroid/media/MediaCodec$BufferInfo;->presentationTimeUs:J
    invoke-virtual {v1, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
    invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v1
    .line 821
    invoke-static {p3, v1}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    goto :goto_c1
    :cond_103
    const/4 p3, -0x1
    const/16 v1, 0x7d0
    if-nez v0, :cond_122
    const-string v0, "HardwareVideoDecoder"
    .line 827
    new-instance v1, Ljava/lang/StringBuilder;
    invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
    const-string v2, "decodeTimeStamps empty. cannot find: "
    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget-wide v2, p2, Landroid/media/MediaCodec$BufferInfo;->presentationTimeUs:J
    invoke-virtual {v1, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
    invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p2
    invoke-static {v0, p2}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
    move v8, p3
    goto :goto_14c
    .line 829
    :cond_122
    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
    move-result-wide p2
    # getter for: Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;->decodeStartTimeMs:J
    invoke-static {v0}, Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;->access$1400(Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;)J
    move-result-wide v2
    sub-long/2addr p2, v2
    long-to-int p2, p2
    if-le p2, v1, :cond_14b
    const-string p3, "HardwareVideoDecoder"
    .line 831
    new-instance v0, Ljava/lang/StringBuilder;
    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
    const-string v2, "Very high decode time: "
    invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    const-string p2, "ms."
    invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p2
    invoke-static {p3, p2}, Lio/agora/base/internal/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
    move v8, v1
    goto :goto_14c
    :cond_14b
    move v8, p2
    .line 835
    :goto_14c
    iget-object v4, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->callback:Lio/agora/base/internal/video/VideoDecoder$Callback;
    const/4 v7, 0x0
    move-object v5, p1
    move-object v6, p4
    invoke-interface/range {v4 .. v10}, Lio/agora/base/internal/video/VideoDecoder$Callback;->onDecodedFrame(Lio/agora/base/VideoFrame;Ljava/lang/Integer;Ljava/lang/Integer;IILio/agora/base/internal/video/CodecSpecificInfo;)V
    .line 837
    invoke-virtual {p1}, Lio/agora/base/VideoFrame;->release()V
    return-void
    :catchall_158
    move-exception p1
    .line 766
    :try_start_159
    monitor-exit v0
    :try_end_15a
    .catchall {:try_start_159 .. :try_end_15a} :catchall_158
    throw p1
.end method
.method private deliverTextureFrame(ILandroid/media/MediaCodec$BufferInfo;ILjava/lang/Integer;)V
    .registers 14
    .line 656
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->dimensionLock:Ljava/lang/Object;
    monitor-enter v0
    .line 657
    :try_start_3
    iget v3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->width:I
    .line 658
    iget v4, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->height:I
    .line 659
    monitor-exit v0
    :try_end_8
    .catchall {:try_start_3 .. :try_end_8} :catchall_5b
    .line 661
    new-instance v0, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;
    iget-wide v6, p2, Landroid/media/MediaCodec$BufferInfo;->presentationTimeUs:J
    move-object v1, v0
    move v2, p1
    move v5, p3
    move-object v8, p4
    invoke-direct/range {v1 .. v8}, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;-><init>(IIIIJLjava/lang/Integer;)V
    .line 663
    iget-object p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->textureMetadataLock:Ljava/lang/Object;
    monitor-enter p1
    .line 664
    :try_start_16
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->dequeuedSurfaceOutputBuffers:Ljava/util/Queue;
    invoke-interface {p2, v0}, Ljava/util/Queue;->offer(Ljava/lang/Object;)Z
    .line 665
    invoke-direct {p0}, Lio/agora/base/internal/video/HardwareVideoDecoder;->maybeRenderDecodedTextureBuffer()V
    .line 668
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->dequeuedSurfaceOutputBuffers:Ljava/util/Queue;
    invoke-interface {p2}, Ljava/util/Queue;->size()I
    move-result p2
    const/4 p3, 0x3
    if-lt p2, p3, :cond_56
    .line 669
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->dequeuedSurfaceOutputBuffers:Ljava/util/Queue;
    invoke-interface {p2}, Ljava/util/Queue;->poll()Ljava/lang/Object;
    move-result-object p2
    check-cast p2, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;
    .line 670
    new-instance p3, Ljava/lang/StringBuilder;
    invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
    const-string p4, "drop the oldest output frame in cache, pts_us: "
    invoke-virtual {p3, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget-wide v0, p2, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;->presentationTimestampUs:J
    invoke-virtual {p3, v0, v1}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
    invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p3
    invoke-static {p3}, Lio/agora/base/internal/video/HardwareVideoDecoder;->debug_log(Ljava/lang/String;)V
    :try_end_45
    .catchall {:try_start_16 .. :try_end_45} :catchall_58
    .line 673
    :try_start_45
    iget-object p3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    iget p2, p2, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;->outputBufferIndex:I
    const/4 p4, 0x0
    invoke-interface {p3, p2, p4}, Lio/agora/base/internal/video/MediaCodecWrapper;->releaseOutputBuffer(IZ)V
    :try_end_4d
    .catch Ljava/lang/IllegalStateException; {:try_start_45 .. :try_end_4d} :catch_4e
    .catchall {:try_start_45 .. :try_end_4d} :catchall_58
    goto :goto_56
    :catch_4e
    move-exception p2
    :try_start_4f
    const-string p3, "HardwareVideoDecoder"
    const-string p4, "deliverTextureFrame failed"
    .line 675
    invoke-static {p3, p4, p2}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .line 678
    :cond_56
    :goto_56
    monitor-exit p1
    return-void
    :catchall_58
    move-exception p2
    monitor-exit p1
    :try_end_5a
    .catchall {:try_start_4f .. :try_end_5a} :catchall_58
    throw p2
    :catchall_5b
    move-exception p1
    .line 659
    :try_start_5c
    monitor-exit v0
    :try_end_5d
    .catchall {:try_start_5c .. :try_end_5d} :catchall_5b
    throw p1
.end method
.method private deliverToDirectSurface(ILandroid/media/MediaCodec$BufferInfo;ILjava/lang/Integer;)V
    .registers 5
    .line 645
    :try_start_0
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    const/4 p3, 0x1
    invoke-interface {p2, p1, p3}, Lio/agora/base/internal/video/MediaCodecWrapper;->releaseOutputBuffer(IZ)V
    :try_end_6
    .catch Ljava/lang/IllegalStateException; {:try_start_0 .. :try_end_6} :catch_7
    goto :goto_f
    :catch_7
    move-exception p1
    const-string p2, "HardwareVideoDecoder"
    const-string p3, "deliverToDirectSurface failed"
    .line 647
    invoke-static {p2, p3, p1}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    :goto_f
    return-void
.end method
.method private initDecodeInternal(II)Lio/agora/base/internal/video/VideoCodecStatus;
    .registers 8
    const-string v0, "HardwareVideoDecoder"
    const-string v1, "initDecodeInternal"
    .line 240
    invoke-static {v0, v1}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    .line 241
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->proxyThreadHandler:Landroid/os/Handler;
    if-nez v0, :cond_e
    .line 242
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->FALLBACK_SOFTWARE:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
    .line 244
    :cond_e
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->outputThread:Ljava/lang/Thread;
    if-eqz v0, :cond_1c
    const-string p1, "HardwareVideoDecoder"
    const-string p2, "initDecodeInternal called while the codec is already running"
    .line 245
    invoke-static {p1, p2}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
    .line 246
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->FALLBACK_SOFTWARE:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
    .line 251
    :cond_1c
    iput p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->width:I
    .line 252
    iput p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->height:I
    .line 254
    iput p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->stride:I
    .line 255
    iput p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->sliceHeight:I
    const/4 v0, 0x0
    .line 256
    iput-boolean v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->hasDecodedFirstFrame:Z
    const/4 v1, 0x1
    .line 257
    iput-boolean v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->keyFrameRequired:Z
    .line 258
    iget-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->decodeTimeStamps:Ljava/util/Queue;
    invoke-interface {v2}, Ljava/util/Queue;->clear()V
    .line 260
    iget-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecName:Ljava/lang/String;
    if-eqz v2, :cond_66
    sget-object v2, Landroid/os/Build;->HARDWARE:Ljava/lang/String;
    if-eqz v2, :cond_66
    iget-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecName:Ljava/lang/String;
    const-string v3, "OMX.hisi."
    invoke-virtual {v2, v3}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
    move-result v2
    if-eqz v2, :cond_66
    sget-object v2, Landroid/os/Build;->HARDWARE:Ljava/lang/String;
    const-string v3, "bigfish"
    .line 261
    invoke-virtual {v2, v3}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
    move-result v2
    if-eqz v2, :cond_66
    .line 262
    iput-boolean v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->isHisiCodec:Z
    const-string v0, "HardwareVideoDecoder"
    .line 263
    new-instance v2, Ljava/lang/StringBuilder;
    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
    const-string v3, " bigfish isHisiCodec: "
    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget-boolean v3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->isHisiCodec:Z
    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v2
    invoke-static {v0, v2}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    goto :goto_68
    .line 265
    :cond_66
    iput-boolean v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->isHisiCodec:Z
    .line 269
    :goto_68
    new-instance v0, Lio/agora/base/internal/video/HardwareVideoDecoder$1;
    invoke-direct {v0, p0}, Lio/agora/base/internal/video/HardwareVideoDecoder$1;-><init>(Lio/agora/base/internal/video/HardwareVideoDecoder;)V
    .line 283
    :try_start_6d
    iget-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->proxyThreadHandler:Landroid/os/Handler;
    const-wide/16 v3, 0x7d0
    invoke-static {v2, v3, v4, v0}, Lio/agora/base/internal/ThreadUtils;->invokeAtFrontUninterruptibly(Landroid/os/Handler;JLjava/util/concurrent/Callable;)Ljava/lang/Object;
    move-result-object v0
    check-cast v0, Lio/agora/base/internal/video/VideoCodecStatus;
    if-nez v0, :cond_7c
    .line 285
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->FALLBACK_SOFTWARE:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
    .line 287
    :cond_7c
    sget-object v2, Lio/agora/base/internal/video/VideoCodecStatus;->OK:Lio/agora/base/internal/video/VideoCodecStatus;
    :try_end_7e
    .catch Ljava/lang/Exception; {:try_start_6d .. :try_end_7e} :catch_104
    if-eq v0, v2, :cond_81
    return-object v0
    .line 294
    :cond_81
    invoke-direct {p0}, Lio/agora/base/internal/video/HardwareVideoDecoder;->readVideoCapabilities()V
    .line 295
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecType:Lio/agora/base/internal/video/VideoCodecType;
    invoke-virtual {v0}, Lio/agora/base/internal/video/VideoCodecType;->mimeType()Ljava/lang/String;
    move-result-object v0
    invoke-static {v0, p1, p2}, Landroid/media/MediaFormat;->createVideoFormat(Ljava/lang/String;II)Landroid/media/MediaFormat;
    move-result-object p1
    .line 296
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->sharedContext:Lio/agora/base/internal/video/EglBase$Context;
    if-nez p2, :cond_9d
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->directSurface:Landroid/view/Surface;
    if-nez p2, :cond_9d
    const-string p2, "color-format"
    .line 297
    iget v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->colorFormat:I
    invoke-virtual {p1, p2, v0}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V
    .line 299
    :cond_9d
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->params:Ljava/util/Map;
    const-string v0, "av_dec_video_hwdec_config"
    invoke-interface {p2, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
    move-result-object p2
    check-cast p2, Ljava/lang/String;
    iput-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->customConfigJson:Ljava/lang/String;
    .line 300
    invoke-static {p1, p2}, Lio/agora/base/internal/video/MediaCodecUtils;->applyCustomConfig(Landroid/media/MediaFormat;Ljava/lang/String;)V
    .line 302
    new-instance p2, Lio/agora/base/internal/video/HardwareVideoDecoder$2;
    invoke-direct {p2, p0, p1}, Lio/agora/base/internal/video/HardwareVideoDecoder$2;-><init>(Lio/agora/base/internal/video/HardwareVideoDecoder;Landroid/media/MediaFormat;)V
    .line 317
    :try_start_b1
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->proxyThreadHandler:Landroid/os/Handler;
    invoke-static {v0, v3, v4, p2}, Lio/agora/base/internal/ThreadUtils;->invokeAtFrontUninterruptibly(Landroid/os/Handler;JLjava/util/concurrent/Callable;)Ljava/lang/Object;
    move-result-object p2
    check-cast p2, Lio/agora/base/internal/video/VideoCodecStatus;
    if-nez p2, :cond_be
    .line 319
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->FALLBACK_SOFTWARE:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
    .line 321
    :cond_be
    sget-object v0, Lio/agora/base/internal/video/VideoCodecStatus;->OK:Lio/agora/base/internal/video/VideoCodecStatus;
    :try_end_c0
    .catch Ljava/lang/Exception; {:try_start_b1 .. :try_end_c0} :catch_101
    if-eq p2, v0, :cond_c3
    return-object p2
    .line 328
    :cond_c3
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->textureMetadataLock:Ljava/lang/Object;
    monitor-enter p2
    .line 329
    :try_start_c6
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->dequeuedSurfaceOutputBuffers:Ljava/util/Queue;
    invoke-interface {v0}, Ljava/util/Queue;->clear()V
    .line 330
    monitor-exit p2
    :try_end_cc
    .catchall {:try_start_c6 .. :try_end_cc} :catchall_fe
    .line 332
    iput-boolean v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->running:Z
    .line 333
    invoke-direct {p0}, Lio/agora/base/internal/video/HardwareVideoDecoder;->createOutputThread()Ljava/lang/Thread;
    move-result-object p2
    iput-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->outputThread:Ljava/lang/Thread;
    .line 334
    invoke-virtual {p2}, Ljava/lang/Thread;->start()V
    const-string p2, "HardwareVideoDecoder"
    .line 336
    new-instance v0, Ljava/lang/StringBuilder;
    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
    const-string v1, "initDecodeInternal "
    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecType:Lio/agora/base/internal/video/VideoCodecType;
    invoke-virtual {v1}, Lio/agora/base/internal/video/VideoCodecType;->mimeType()Ljava/lang/String;
    move-result-object v1
    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    const-string v1, " done, format: "
    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p1
    invoke-static {p2, p1}, Lio/agora/base/internal/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
    .line 337
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->OK:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
    :catchall_fe
    move-exception p1
    .line 330
    :try_start_ff
    monitor-exit p2
    :try_end_100
    .catchall {:try_start_ff .. :try_end_100} :catchall_fe
    throw p1
    .line 325
    :catch_101
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->FALLBACK_SOFTWARE:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
    .line 291
    :catch_104
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->FALLBACK_SOFTWARE:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
.end method
.method private isSupportedColorFormat(I)Z
    .registers 7
    .line 1001
    sget-object v0, Lio/agora/base/internal/video/MediaCodecUtils;->DECODER_COLOR_FORMATS:[I
    array-length v1, v0
    const/4 v2, 0x0
    move v3, v2
    :goto_5
    if-ge v3, v1, :cond_10
    aget v4, v0, v3
    if-ne v4, p1, :cond_d
    const/4 p1, 0x1
    return p1
    :cond_d
    add-int/lit8 v3, v3, 0x1
    goto :goto_5
    :cond_10
    return v2
.end method
.method private isSupportedColorFormatHDR(I)Z
    .registers 7
    .line 1010
    sget-object v0, Lio/agora/base/internal/video/MediaCodecUtils;->DECODER_COLOR_FORMATS_HDR:[I
    array-length v1, v0
    const/4 v2, 0x0
    move v3, v2
    :goto_5
    if-ge v3, v1, :cond_10
    aget v4, v0, v3
    if-ne v4, p1, :cond_d
    const/4 p1, 0x1
    return p1
    :cond_d
    add-int/lit8 v3, v3, 0x1
    goto :goto_5
    :cond_10
    return v2
.end method
.method private maybeRenderDecodedTextureBuffer()V
    .registers 6
    .line 1020
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->renderedTextureMetadata:Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;
    if-eqz v0, :cond_5
    return-void
    .line 1023
    :cond_5
    iget-boolean v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->running:Z
    const-string v1, "HardwareVideoDecoder"
    if-nez v0, :cond_11
    const-string v0, "RenderTexture: Decoder is not running."
    .line 1024
    invoke-static {v1, v0}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    return-void
    .line 1028
    :cond_11
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->dequeuedSurfaceOutputBuffers:Ljava/util/Queue;
    invoke-interface {v0}, Ljava/util/Queue;->poll()Ljava/lang/Object;
    move-result-object v0
    check-cast v0, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;
    if-nez v0, :cond_1c
    return-void
    .line 1034
    :cond_1c
    :try_start_1c
    iget-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surfaceTextureHelper:Lio/agora/base/internal/video/SurfaceTextureHelper;
    iget v3, v0, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;->width:I
    iget v4, v0, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;->height:I
    invoke-virtual {v2, v3, v4}, Lio/agora/base/internal/video/SurfaceTextureHelper;->setTextureSize(II)V
    :try_end_25
    .catch Ljava/lang/IllegalArgumentException; {:try_start_1c .. :try_end_25} :catch_26
    goto :goto_2c
    :catch_26
    move-exception v2
    const-string v3, "setTextureSize:"
    .line 1036
    invoke-static {v1, v3, v2}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .line 1038
    :goto_2c
    iget-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surfaceTextureHelper:Lio/agora/base/internal/video/SurfaceTextureHelper;
    iget v3, v0, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;->rotation:I
    invoke-virtual {v2, v3}, Lio/agora/base/internal/video/SurfaceTextureHelper;->setFrameRotation(I)V
    .line 1039
    iput-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->renderedTextureMetadata:Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;
    .line 1040
    new-instance v2, Ljava/lang/StringBuilder;
    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
    const-string v3, "render output buffer to surface, pts_us: "
    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget-wide v3, v0, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;->presentationTimestampUs:J
    invoke-virtual {v2, v3, v4}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v2
    invoke-static {v2}, Lio/agora/base/internal/video/HardwareVideoDecoder;->debug_log(Ljava/lang/String;)V
    .line 1042
    :try_start_4b
    iget-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    iget v0, v0, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;->outputBufferIndex:I
    const/4 v3, 0x1
    invoke-interface {v2, v0, v3}, Lio/agora/base/internal/video/MediaCodecWrapper;->releaseOutputBuffer(IZ)V
    :try_end_53
    .catch Ljava/lang/IllegalStateException; {:try_start_4b .. :try_end_53} :catch_5b
    .catch Ljava/lang/Exception; {:try_start_4b .. :try_end_53} :catch_54
    goto :goto_61
    :catch_54
    move-exception v0
    const-string v2, "deliverToDirectSurface error"
    .line 1046
    invoke-static {v1, v2, v0}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    goto :goto_61
    :catch_5b
    move-exception v0
    const-string v2, "deliverToDirectSurface failed"
    .line 1044
    invoke-static {v1, v2, v0}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    :goto_61
    return-void
.end method
.method private readVideoCapabilities()V
    .registers 9
    const-string v0, "HardwareVideoDecoder"
    .line 341
    sget v1, Landroid/os/Build$VERSION;->SDK_INT:I
    const/16 v2, 0x15
    if-ge v1, v2, :cond_9
    return-void
    :cond_9
    const/4 v1, 0x0
    .line 347
    :try_start_a
    iget-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    iget-object v3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecType:Lio/agora/base/internal/video/VideoCodecType;
    invoke-virtual {v3}, Lio/agora/base/internal/video/VideoCodecType;->mimeType()Ljava/lang/String;
    move-result-object v3
    invoke-interface {v2, v3}, Lio/agora/base/internal/video/MediaCodecWrapper;->getCodecInfo(Ljava/lang/String;)Landroid/media/MediaCodecInfo$CodecCapabilities;
    move-result-object v1
    :try_end_16
    .catch Ljava/lang/Exception; {:try_start_a .. :try_end_16} :catch_17
    goto :goto_2d
    .line 349
    :catch_17
    new-instance v2, Ljava/lang/StringBuilder;
    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
    const-string v3, "Cannot get CodecInfo "
    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget-object v3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecName:Ljava/lang/String;
    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v2
    invoke-static {v0, v2}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
    :goto_2d
    if-nez v1, :cond_30
    return-void
    .line 355
    :cond_30
    invoke-virtual {v1}, Landroid/media/MediaCodecInfo$CodecCapabilities;->getVideoCapabilities()Landroid/media/MediaCodecInfo$VideoCapabilities;
    move-result-object v2
    if-nez v2, :cond_37
    return-void
    .line 360
    :cond_37
    invoke-virtual {v2}, Landroid/media/MediaCodecInfo$VideoCapabilities;->getSupportedWidths()Landroid/util/Range;
    move-result-object v3
    const/4 v4, 0x0
    if-eqz v3, :cond_53
    .line 363
    invoke-virtual {v3}, Landroid/util/Range;->getUpper()Ljava/lang/Comparable;
    move-result-object v5
    check-cast v5, Ljava/lang/Integer;
    invoke-virtual {v5}, Ljava/lang/Integer;->intValue()I
    move-result v5
    .line 364
    invoke-virtual {v3}, Landroid/util/Range;->getLower()Ljava/lang/Comparable;
    move-result-object v3
    check-cast v3, Ljava/lang/Integer;
    invoke-virtual {v3}, Ljava/lang/Integer;->intValue()I
    move-result v3
    goto :goto_55
    :cond_53
    move v3, v4
    move v5, v3
    .line 366
    :goto_55
    invoke-virtual {v2}, Landroid/media/MediaCodecInfo$VideoCapabilities;->getSupportedHeights()Landroid/util/Range;
    move-result-object v2
    if-eqz v2, :cond_70
    .line 368
    invoke-virtual {v2}, Landroid/util/Range;->getUpper()Ljava/lang/Comparable;
    move-result-object v4
    check-cast v4, Ljava/lang/Integer;
    invoke-virtual {v4}, Ljava/lang/Integer;->intValue()I
    move-result v4
    .line 369
    invoke-virtual {v2}, Landroid/util/Range;->getLower()Ljava/lang/Comparable;
    move-result-object v2
    check-cast v2, Ljava/lang/Integer;
    invoke-virtual {v2}, Ljava/lang/Integer;->intValue()I
    move-result v2
    goto :goto_71
    :cond_70
    move v2, v4
    .line 371
    :goto_71
    new-instance v6, Ljava/lang/StringBuilder;
    invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
    iget-object v7, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecType:Lio/agora/base/internal/video/VideoCodecType;
    .line 372
    invoke-virtual {v7}, Lio/agora/base/internal/video/VideoCodecType;->mimeType()Ljava/lang/String;
    move-result-object v7
    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    const-string v7, "  max supported size:"
    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v6, v5}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    const-string/jumbo v5, "x"
    invoke-virtual {v6, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    const-string v4, " min supported size:"
    invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v6, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    invoke-virtual {v6, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v6, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v2
    .line 371
    invoke-static {v0, v2}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    .line 375
    sget v2, Landroid/os/Build$VERSION;->SDK_INT:I
    const/16 v3, 0x17
    if-lt v2, v3, :cond_c3
    .line 376
    new-instance v2, Ljava/lang/StringBuilder;
    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
    const-string v3, "max supported instance: "
    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v1}, Landroid/media/MediaCodecInfo$CodecCapabilities;->getMaxSupportedInstances()I
    move-result v1
    invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v1
    invoke-static {v0, v1}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    :cond_c3
    return-void
.end method
.method private reformat(Landroid/media/MediaFormat;)V
    .registers 7
    .line 912
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->outputThreadChecker:Lio/agora/base/internal/ThreadUtils$ThreadChecker;
    invoke-virtual {v0}, Lio/agora/base/internal/ThreadUtils$ThreadChecker;->checkIsOnValidThread()V
    const-string v0, "HardwareVideoDecoder"
    .line 913
    new-instance v1, Ljava/lang/StringBuilder;
    invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
    const-string v2, "Decoder format changed: "
    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {p1}, Landroid/media/MediaFormat;->toString()Ljava/lang/String;
    move-result-object v2
    invoke-virtual {v1, v2}, 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 {v0, v1}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    const-string v0, "crop-left"
    .line 916
    invoke-virtual {p1, v0}, Landroid/media/MediaFormat;->containsKey(Ljava/lang/String;)Z
    move-result v0
    if-eqz v0, :cond_5e
    const-string v0, "crop-right"
    .line 917
    invoke-virtual {p1, v0}, Landroid/media/MediaFormat;->containsKey(Ljava/lang/String;)Z
    move-result v0
    if-eqz v0, :cond_5e
    const-string v0, "crop-bottom"
    .line 918
    invoke-virtual {p1, v0}, Landroid/media/MediaFormat;->containsKey(Ljava/lang/String;)Z
    move-result v0
    if-eqz v0, :cond_5e
    const-string v0, "crop-top"
    .line 919
    invoke-virtual {p1, v0}, Landroid/media/MediaFormat;->containsKey(Ljava/lang/String;)Z
    move-result v0
    if-eqz v0, :cond_5e
    const-string v0, "crop-right"
    .line 920
    invoke-virtual {p1, v0}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v0
    add-int/lit8 v0, v0, 0x1
    const-string v1, "crop-left"
    .line 921
    invoke-virtual {p1, v1}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v1
    sub-int/2addr v0, v1
    const-string v1, "crop-bottom"
    .line 922
    invoke-virtual {p1, v1}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v1
    add-int/lit8 v1, v1, 0x1
    const-string v2, "crop-top"
    .line 923
    invoke-virtual {p1, v2}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v2
    sub-int/2addr v1, v2
    goto :goto_6b
    :cond_5e
    const-string/jumbo v0, "width"
    .line 925
    invoke-virtual {p1, v0}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v0
    const-string v1, "height"
    .line 926
    invoke-virtual {p1, v1}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v1
    .line 929
    :goto_6b
    iget-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->dimensionLock:Ljava/lang/Object;
    monitor-enter v2
    .line 930
    :try_start_6e
    iget-boolean v3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->hasDecodedFirstFrame:Z
    if-eqz v3, :cond_b1
    iget v3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->width:I
    if-ne v3, v0, :cond_7a
    iget v3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->height:I
    if-eq v3, v1, :cond_b1
    .line 931
    :cond_7a
    new-instance p1, Ljava/lang/RuntimeException;
    new-instance v3, Ljava/lang/StringBuilder;
    invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
    const-string v4, "Unexpected size change. Configured "
    invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget v4, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->width:I
    invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    const-string v4, "*"
    invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget v4, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->height:I
    invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    const-string v4, ". New "
    invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    const-string v0, "*"
    invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v0
    invoke-direct {p1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
    invoke-direct {p0, p1}, Lio/agora/base/internal/video/HardwareVideoDecoder;->stopOnOutputThread(Ljava/lang/Exception;)V
    .line 933
    monitor-exit v2
    return-void
    .line 935
    :cond_b1
    iput v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->width:I
    .line 936
    iput v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->height:I
    .line 937
    monitor-exit v2
    :try_end_b6
    .catchall {:try_start_6e .. :try_end_b6} :catchall_17d
    .line 941
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surfaceTextureHelper:Lio/agora/base/internal/video/SurfaceTextureHelper;
    if-nez v0, :cond_11f
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->directSurface:Landroid/view/Surface;
    if-nez v0, :cond_11f
    const-string v0, "color-format"
    .line 942
    invoke-virtual {p1, v0}, Landroid/media/MediaFormat;->containsKey(Ljava/lang/String;)Z
    move-result v0
    if-eqz v0, :cond_11f
    const-string v0, "color-format"
    .line 943
    invoke-virtual {p1, v0}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v0
    const-string v1, "HardwareVideoDecoder"
    .line 944
    new-instance v2, Ljava/lang/StringBuilder;
    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
    const-string v3, "reformat, Color: 0x"
    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-static {v0}, Ljava/lang/Integer;->toHexString(I)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 {v1, v2}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    .line 946
    iget-boolean v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->isHisiCodec:Z
    if-eqz v1, :cond_f9
    const/16 v1, 0x2f
    if-ne v0, v1, :cond_f9
    sget v1, Landroid/os/Build$VERSION;->SDK_INT:I
    const/16 v2, 0x15
    if-lt v1, v2, :cond_f9
    const/16 v0, 0x27
    .line 948
    iput v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->colorFormat:I
    goto :goto_fb
    .line 950
    :cond_f9
    iput v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->colorFormat:I
    .line 952
    :goto_fb
    iget v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->colorFormat:I
    invoke-direct {p0, v0}, Lio/agora/base/internal/video/HardwareVideoDecoder;->isSupportedColorFormat(I)Z
    move-result v0
    if-nez v0, :cond_11f
    .line 953
    new-instance p1, Ljava/lang/IllegalStateException;
    new-instance v0, Ljava/lang/StringBuilder;
    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
    const-string v1, "Unsupported color format: "
    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->colorFormat: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-direct {p1, v0}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
    invoke-direct {p0, p1}, Lio/agora/base/internal/video/HardwareVideoDecoder;->stopOnOutputThread(Ljava/lang/Exception;)V
    return-void
    .line 959
    :cond_11f
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->dimensionLock:Ljava/lang/Object;
    monitor-enter v0
    :try_start_122
    const-string v1, "stride"
    .line 960
    invoke-virtual {p1, v1}, Landroid/media/MediaFormat;->containsKey(Ljava/lang/String;)Z
    move-result v1
    if-eqz v1, :cond_132
    const-string v1, "stride"
    .line 961
    invoke-virtual {p1, v1}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result v1
    iput v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->stride:I
    :cond_132
    const-string v1, "slice-height"
    .line 963
    invoke-virtual {p1, v1}, Landroid/media/MediaFormat;->containsKey(Ljava/lang/String;)Z
    move-result v1
    if-eqz v1, :cond_142
    const-string v1, "slice-height"
    .line 964
    invoke-virtual {p1, v1}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
    move-result p1
    iput p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->sliceHeight:I
    :cond_142
    const-string p1, "HardwareVideoDecoder"
    .line 966
    new-instance v1, Ljava/lang/StringBuilder;
    invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
    const-string v2, "Frame stride and slice height: "
    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->stride:I
    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    const-string v2, " x "
    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->sliceHeight:I
    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v1
    invoke-static {p1, v1}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    .line 967
    iget p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->width:I
    iget v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->stride:I
    invoke-static {p1, v1}, Ljava/lang/Math;->max(II)I
    move-result p1
    iput p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->stride:I
    .line 968
    iget p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->height:I
    iget v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->sliceHeight:I
    invoke-static {p1, v1}, Ljava/lang/Math;->max(II)I
    move-result p1
    iput p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->sliceHeight:I
    .line 969
    monitor-exit v0
    return-void
    :catchall_17a
    move-exception p1
    monitor-exit v0
    :try_end_17c
    .catchall {:try_start_122 .. :try_end_17c} :catchall_17a
    throw p1
    :catchall_17d
    move-exception p1
    .line 937
    :try_start_17e
    monitor-exit v2
    :try_end_17f
    .catchall {:try_start_17e .. :try_end_17f} :catchall_17d
    throw p1
.end method
.method private reinitDecode(II)Lio/agora/base/internal/video/VideoCodecStatus;
    .registers 5
    .line 579
    invoke-direct {p0}, Lio/agora/base/internal/video/HardwareVideoDecoder;->releaseInternal()Lio/agora/base/internal/video/VideoCodecStatus;
    move-result-object v0
    .line 580
    sget-object v1, Lio/agora/base/internal/video/VideoCodecStatus;->OK:Lio/agora/base/internal/video/VideoCodecStatus;
    if-eq v0, v1, :cond_9
    return-object v0
    .line 583
    :cond_9
    invoke-direct {p0, p1, p2}, Lio/agora/base/internal/video/HardwareVideoDecoder;->initDecodeInternal(II)Lio/agora/base/internal/video/VideoCodecStatus;
    move-result-object p1
    return-object p1
.end method
.method private releaseCodecOnOutputThread()V
    .registers 4
    .line 973
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->outputThreadChecker:Lio/agora/base/internal/ThreadUtils$ThreadChecker;
    invoke-virtual {v0}, Lio/agora/base/internal/ThreadUtils$ThreadChecker;->checkIsOnValidThread()V
    const-string v0, "HardwareVideoDecoder"
    const-string v1, "Releasing MediaCodec on output thread"
    .line 974
    invoke-static {v0, v1}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    .line 976
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->textureMetadataLock:Ljava/lang/Object;
    monitor-enter v0
    .line 977
    :try_start_f
    iget-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->dequeuedSurfaceOutputBuffers:Ljava/util/Queue;
    invoke-interface {v1}, Ljava/util/Queue;->clear()V
    .line 978
    monitor-exit v0
    :try_end_15
    .catchall {:try_start_f .. :try_end_15} :catchall_3b
    .line 980
    :try_start_15
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    invoke-interface {v0}, Lio/agora/base/internal/video/MediaCodecWrapper;->stop()V
    :try_end_1a
    .catch Ljava/lang/Exception; {:try_start_15 .. :try_end_1a} :catch_1b
    goto :goto_23
    :catch_1b
    move-exception v0
    const-string v1, "HardwareVideoDecoder"
    const-string v2, "Media decoder stop failed"
    .line 982
    invoke-static {v1, v2, v0}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .line 985
    :goto_23
    :try_start_23
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    invoke-interface {v0}, Lio/agora/base/internal/video/MediaCodecWrapper;->release()V
    :try_end_28
    .catch Ljava/lang/Exception; {:try_start_23 .. :try_end_28} :catch_29
    goto :goto_33
    :catch_29
    move-exception v0
    const-string v1, "HardwareVideoDecoder"
    const-string v2, "Media decoder release failed"
    .line 987
    invoke-static {v1, v2, v0}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .line 989
    iput-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->shutdownException:Ljava/lang/Exception;
    :goto_33
    const-string v0, "HardwareVideoDecoder"
    const-string v1, "Release on output thread done"
    .line 991
    invoke-static {v0, v1}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    return-void
    :catchall_3b
    move-exception v1
    .line 978
    :try_start_3c
    monitor-exit v0
    :try_end_3d
    .catchall {:try_start_3c .. :try_end_3d} :catchall_3b
    throw v1
.end method
.method private releaseInternal()Lio/agora/base/internal/video/VideoCodecStatus;
    .registers 6
    .line 552
    iget-boolean v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->running:Z
    const-string v1, "HardwareVideoDecoder"
    if-nez v0, :cond_e
    const-string v0, "release: Decoder is not running."
    .line 553
    invoke-static {v1, v0}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    .line 554
    sget-object v0, Lio/agora/base/internal/video/VideoCodecStatus;->OK:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object v0
    :cond_e
    const/4 v0, 0x0
    const/4 v2, 0x0
    .line 558
    :try_start_10
    iput-boolean v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->running:Z
    .line 559
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->outputThread:Ljava/lang/Thread;
    const-wide/16 v3, 0x1388
    invoke-static {v0, v3, v4}, Lio/agora/base/internal/ThreadUtils;->joinUninterruptibly(Ljava/lang/Thread;J)Z
    move-result v0
    if-nez v0, :cond_2d
    const-string v0, "Media decoder release timeout"
    .line 561
    new-instance v3, Ljava/lang/RuntimeException;
    invoke-direct {v3}, Ljava/lang/RuntimeException;-><init>()V
    invoke-static {v1, v0, v3}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .line 562
    sget-object v0, Lio/agora/base/internal/video/VideoCodecStatus;->TIMEOUT:Lio/agora/base/internal/video/VideoCodecStatus;
    :try_end_28
    .catchall {:try_start_10 .. :try_end_28} :catchall_4d
    .line 572
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    .line 573
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->outputThread:Ljava/lang/Thread;
    return-object v0
    .line 564
    :cond_2d
    :try_start_2d
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->shutdownException:Ljava/lang/Exception;
    if-eqz v0, :cond_46
    const-string v0, "Media decoder release error"
    .line 567
    new-instance v3, Ljava/lang/RuntimeException;
    iget-object v4, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->shutdownException:Ljava/lang/Exception;
    invoke-direct {v3, v4}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
    invoke-static {v1, v0, v3}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .line 568
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->shutdownException:Ljava/lang/Exception;
    .line 569
    sget-object v0, Lio/agora/base/internal/video/VideoCodecStatus;->ERROR:Lio/agora/base/internal/video/VideoCodecStatus;
    :try_end_41
    .catchall {:try_start_2d .. :try_end_41} :catchall_4d
    .line 572
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    .line 573
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->outputThread:Ljava/lang/Thread;
    return-object v0
    .line 572
    :cond_46
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    .line 573
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->outputThread:Ljava/lang/Thread;
    .line 575
    sget-object v0, Lio/agora/base/internal/video/VideoCodecStatus;->OK:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object v0
    :catchall_4d
    move-exception v0
    .line 572
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    .line 573
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->outputThread:Ljava/lang/Thread;
    throw v0
.end method
.method private stopOnOutputThread(Ljava/lang/Exception;)V
    .registers 3
    .line 995
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->outputThreadChecker:Lio/agora/base/internal/ThreadUtils$ThreadChecker;
    invoke-virtual {v0}, Lio/agora/base/internal/ThreadUtils$ThreadChecker;->checkIsOnValidThread()V
    const/4 v0, 0x0
    .line 996
    iput-boolean v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->running:Z
    .line 997
    iput-object p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->shutdownException:Ljava/lang/Exception;
    return-void
.end method
# virtual methods
.method protected allocateI420Buffer(II)Lio/agora/base/VideoFrame$I420Buffer;
    .registers 3
    .line 1065
    invoke-static {p1, p2}, Lio/agora/base/JavaI420Buffer;->allocate(II)Lio/agora/base/JavaI420Buffer;
    move-result-object p1
    return-object p1
.end method
.method public attachProxyThread()Lio/agora/base/internal/video/VideoCodecStatus;
    .registers 3
    .line 208
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->proxyThreadHandler:Landroid/os/Handler;
    if-nez v0, :cond_19
    .line 209
    new-instance v0, Landroid/os/HandlerThread;
    const-string v1, "proxyThread-Decoder"
    invoke-direct {v0, v1}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;)V
    .line 210
    invoke-virtual {v0}, Landroid/os/HandlerThread;->start()V
    .line 211
    new-instance v1, Landroid/os/Handler;
    invoke-virtual {v0}, Landroid/os/HandlerThread;->getLooper()Landroid/os/Looper;
    move-result-object v0
    invoke-direct {v1, v0}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V
    iput-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->proxyThreadHandler:Landroid/os/Handler;
    .line 213
    :cond_19
    sget-object v0, Lio/agora/base/internal/video/VideoCodecStatus;->OK:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object v0
.end method
.method protected copyPlane(Ljava/nio/ByteBuffer;ILjava/nio/ByteBuffer;III)V
    .registers 7
    .line 1071
    invoke-static/range {p1 .. p6}, Lio/agora/base/internal/video/YuvHelper;->copyPlane(Ljava/nio/ByteBuffer;ILjava/nio/ByteBuffer;III)V
    return-void
.end method
.method public createNativeVideoDecoder()J
    .registers 3
    const-wide/16 v0, 0x0
    return-wide v0
.end method
.method protected createSurfaceTextureHelper()Lio/agora/base/internal/video/SurfaceTextureHelper;
    .registers 4
    .line 1053
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->sharedContext:Lio/agora/base/internal/video/EglBase$Context;
    const-string v1, "decoder-texture-thread"
    const/16 v2, 0x10
    invoke-static {v1, v0, v2}, Lio/agora/base/internal/video/SurfaceTextureHelper;->create(Ljava/lang/String;Lio/agora/base/internal/video/EglBase$Context;I)Lio/agora/base/internal/video/SurfaceTextureHelper;
    move-result-object v0
    return-object v0
.end method
.method public decode(Lio/agora/base/internal/video/EncodedImage;Lio/agora/base/internal/video/VideoDecoder$DecodeInfo;Lio/agora/base/internal/video/CodecSpecificInfo;)Lio/agora/base/internal/video/VideoCodecStatus;
    .registers 8
    .line 383
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    if-eqz p2, :cond_92
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->callback:Lio/agora/base/internal/video/VideoDecoder$Callback;
    if-eqz p2, :cond_92
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->proxyThreadHandler:Landroid/os/Handler;
    if-eqz p2, :cond_92
    iget-boolean p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->running:Z
    if-nez p2, :cond_12
    goto/16 :goto_92
    .line 388
    :cond_12
    iget-object p2, p1, Lio/agora/base/internal/video/EncodedImage;->buffer:Ljava/nio/ByteBuffer;
    if-nez p2, :cond_20
    const-string p1, "HardwareVideoDecoder"
    const-string p2, "decode() - no input data"
    .line 389
    invoke-static {p1, p2}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
    .line 390
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->ERR_PARAMETER:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
    .line 393
    :cond_20
    iget-object p2, p1, Lio/agora/base/internal/video/EncodedImage;->buffer:Ljava/nio/ByteBuffer;
    invoke-virtual {p2}, Ljava/nio/ByteBuffer;->remaining()I
    move-result p2
    if-nez p2, :cond_32
    const-string p1, "HardwareVideoDecoder"
    const-string p2, "decode() - input buffer empty"
    .line 395
    invoke-static {p1, p2}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
    .line 396
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->ERR_PARAMETER:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
    .line 402
    :cond_32
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->dimensionLock:Ljava/lang/Object;
    monitor-enter v0
    .line 403
    :try_start_35
    iget v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->width:I
    .line 404
    iget v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->height:I
    .line 405
    monitor-exit v0
    :try_end_3a
    .catchall {:try_start_35 .. :try_end_3a} :catchall_8f
    .line 408
    iget v0, p1, Lio/agora/base/internal/video/EncodedImage;->encodedWidth:I
    iget v3, p1, Lio/agora/base/internal/video/EncodedImage;->encodedHeight:I
    mul-int/2addr v0, v3
    if-lez v0, :cond_56
    iget v0, p1, Lio/agora/base/internal/video/EncodedImage;->encodedWidth:I
    if-ne v0, v1, :cond_49
    iget v0, p1, Lio/agora/base/internal/video/EncodedImage;->encodedHeight:I
    if-eq v0, v2, :cond_56
    .line 410
    :cond_49
    iget v0, p1, Lio/agora/base/internal/video/EncodedImage;->encodedWidth:I
    iget v1, p1, Lio/agora/base/internal/video/EncodedImage;->encodedHeight:I
    invoke-direct {p0, v0, v1}, Lio/agora/base/internal/video/HardwareVideoDecoder;->reinitDecode(II)Lio/agora/base/internal/video/VideoCodecStatus;
    move-result-object v0
    .line 411
    sget-object v1, Lio/agora/base/internal/video/VideoCodecStatus;->OK:Lio/agora/base/internal/video/VideoCodecStatus;
    if-eq v0, v1, :cond_56
    return-object v0
    .line 416
    :cond_56
    iget-boolean v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->keyFrameRequired:Z
    if-eqz v0, :cond_78
    .line 418
    iget-object v0, p1, Lio/agora/base/internal/video/EncodedImage;->frameType:Lio/agora/base/internal/video/EncodedImage$FrameType;
    sget-object v1, Lio/agora/base/internal/video/EncodedImage$FrameType;->VideoFrameKey:Lio/agora/base/internal/video/EncodedImage$FrameType;
    if-eq v0, v1, :cond_6a
    const-string p1, "HardwareVideoDecoder"
    const-string p2, "decode() - key frame required first"
    .line 419
    invoke-static {p1, p2}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
    .line 420
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->NO_OUTPUT:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
    .line 422
    :cond_6a
    iget-boolean v0, p1, Lio/agora/base/internal/video/EncodedImage;->completeFrame:Z
    if-nez v0, :cond_78
    const-string p1, "HardwareVideoDecoder"
    const-string p2, "decode() - complete frame required first"
    .line 423
    invoke-static {p1, p2}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
    .line 424
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->NO_OUTPUT:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
    .line 428
    :cond_78
    new-instance v0, Lio/agora/base/internal/video/HardwareVideoDecoder$3;
    invoke-direct {v0, p0, p2, p1, p3}, Lio/agora/base/internal/video/HardwareVideoDecoder$3;-><init>(Lio/agora/base/internal/video/HardwareVideoDecoder;ILio/agora/base/internal/video/EncodedImage;Lio/agora/base/internal/video/CodecSpecificInfo;)V
    .line 483
    :try_start_7d
    iget-object p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->proxyThreadHandler:Landroid/os/Handler;
    const-wide/16 p2, 0x7d0
    invoke-static {p1, p2, p3, v0}, Lio/agora/base/internal/ThreadUtils;->invokeAtFrontUninterruptibly(Landroid/os/Handler;JLjava/util/concurrent/Callable;)Ljava/lang/Object;
    move-result-object p1
    check-cast p1, Lio/agora/base/internal/video/VideoCodecStatus;
    if-nez p1, :cond_8b
    .line 485
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->ERROR:Lio/agora/base/internal/video/VideoCodecStatus;
    :try_end_8b
    .catch Ljava/lang/Exception; {:try_start_7d .. :try_end_8b} :catch_8c
    :cond_8b
    return-object p1
    .line 490
    :catch_8c
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->ERROR:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
    :catchall_8f
    move-exception p1
    .line 405
    :try_start_90
    monitor-exit v0
    :try_end_91
    .catchall {:try_start_90 .. :try_end_91} :catchall_8f
    throw p1
    :cond_92
    :goto_92
    const-string p1, "HardwareVideoDecoder"
    .line 384
    new-instance p2, Ljava/lang/StringBuilder;
    invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
    const-string p3, "decode uninitalized, codec: "
    invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget-object p3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    if-eqz p3, :cond_a4
    const/4 p3, 0x1
    goto :goto_a5
    :cond_a4
    const/4 p3, 0x0
    :goto_a5
    invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
    const-string p3, ", callback: "
    invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget-object p3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->callback:Lio/agora/base/internal/video/VideoDecoder$Callback;
    invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
    invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p2
    invoke-static {p1, p2}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    .line 385
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->UNINITIALIZED:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
.end method
.method protected deliverDecodedFrame()V
    .registers 9
    const-string v0, "HardwareVideoDecoder"
    .line 601
    iget-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->outputThreadChecker:Lio/agora/base/internal/ThreadUtils$ThreadChecker;
    invoke-virtual {v1}, Lio/agora/base/internal/ThreadUtils$ThreadChecker;->checkIsOnValidThread()V
    .line 603
    :try_start_7
    new-instance v1, Landroid/media/MediaCodec$BufferInfo;
    invoke-direct {v1}, Landroid/media/MediaCodec$BufferInfo;-><init>()V
    .line 608
    iget-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    const-wide/32 v3, 0x186a0
    invoke-interface {v2, v1, v3, v4}, Lio/agora/base/internal/video/MediaCodecWrapper;->dequeueOutputBuffer(Landroid/media/MediaCodec$BufferInfo;J)I
    move-result v2
    .line 609
    new-instance v3, Ljava/lang/StringBuilder;
    invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
    const-string v4, "dequeue output buffer, pts_us: "
    invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    iget-wide v4, v1, Landroid/media/MediaCodec$BufferInfo;->presentationTimeUs:J
    invoke-virtual {v3, v4, v5}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
    const-string v4, " result: "
    invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v3
    invoke-static {v3}, Lio/agora/base/internal/video/HardwareVideoDecoder;->debug_log(Ljava/lang/String;)V
    const/4 v3, -0x2
    if-ne v2, v3, :cond_40
    .line 611
    iget-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codec:Lio/agora/base/internal/video/MediaCodecWrapper;
    invoke-interface {v1}, Lio/agora/base/internal/video/MediaCodecWrapper;->getOutputFormat()Landroid/media/MediaFormat;
    move-result-object v1
    invoke-direct {p0, v1}, Lio/agora/base/internal/video/HardwareVideoDecoder;->reformat(Landroid/media/MediaFormat;)V
    return-void
    :cond_40
    if-gez v2, :cond_57
    .line 616
    new-instance v1, Ljava/lang/StringBuilder;
    invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
    const-string v3, "dequeueOutputBuffer returned "
    invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v1
    invoke-static {v0, v1}, Lio/agora/base/internal/Logging;->v(Ljava/lang/String;Ljava/lang/String;)V
    return-void
    .line 620
    :cond_57
    iget-object v3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->frameInfos:Ljava/util/concurrent/BlockingDeque;
    invoke-interface {v3}, Ljava/util/concurrent/BlockingDeque;->poll()Ljava/lang/Object;
    move-result-object v3
    check-cast v3, Lio/agora/base/internal/video/HardwareVideoDecoder$FrameInfo;
    const/4 v4, 0x0
    const/4 v5, 0x0
    if-eqz v3, :cond_71
    .line 624
    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
    move-result-wide v4
    iget-wide v6, v3, Lio/agora/base/internal/video/HardwareVideoDecoder$FrameInfo;->decodeStartTimeMs:J
    sub-long/2addr v4, v6
    long-to-int v4, v4
    invoke-static {v4}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
    move-result-object v4
    .line 625
    iget v5, v3, Lio/agora/base/internal/video/HardwareVideoDecoder$FrameInfo;->rotation:I
    :cond_71
    const/4 v3, 0x1
    .line 628
    iput-boolean v3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->hasDecodedFirstFrame:Z
    .line 629
    iget-object v3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->directSurface:Landroid/view/Surface;
    if-eqz v3, :cond_7c
    .line 630
    invoke-direct {p0, v2, v1, v5, v4}, Lio/agora/base/internal/video/HardwareVideoDecoder;->deliverToDirectSurface(ILandroid/media/MediaCodec$BufferInfo;ILjava/lang/Integer;)V
    goto :goto_8e
    .line 631
    :cond_7c
    iget-object v3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surfaceTextureHelper:Lio/agora/base/internal/video/SurfaceTextureHelper;
    if-eqz v3, :cond_84
    .line 632
    invoke-direct {p0, v2, v1, v5, v4}, Lio/agora/base/internal/video/HardwareVideoDecoder;->deliverTextureFrame(ILandroid/media/MediaCodec$BufferInfo;ILjava/lang/Integer;)V
    goto :goto_8e
    .line 634
    :cond_84
    invoke-direct {p0, v2, v1, v5, v4}, Lio/agora/base/internal/video/HardwareVideoDecoder;->deliverByteFrame(ILandroid/media/MediaCodec$BufferInfo;ILjava/lang/Integer;)V
    :try_end_87
    .catch Ljava/lang/IllegalStateException; {:try_start_7 .. :try_end_87} :catch_88
    goto :goto_8e
    :catch_88
    move-exception v1
    const-string v2, "deliverDecodedFrame failed"
    .line 638
    invoke-static {v0, v2, v1}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    :goto_8e
    return-void
.end method
.method public detachProxyThread()Lio/agora/base/internal/video/VideoCodecStatus;
    .registers 3
    .line 542
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->proxyThreadHandler:Landroid/os/Handler;
    if-eqz v0, :cond_13
    const/4 v1, 0x0
    .line 543
    invoke-virtual {v0, v1}, Landroid/os/Handler;->removeCallbacksAndMessages(Ljava/lang/Object;)V
    .line 544
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->proxyThreadHandler:Landroid/os/Handler;
    invoke-virtual {v0}, Landroid/os/Handler;->getLooper()Landroid/os/Looper;
    move-result-object v0
    invoke-virtual {v0}, Landroid/os/Looper;->quitSafely()V
    .line 545
    iput-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->proxyThreadHandler:Landroid/os/Handler;
    .line 547
    :cond_13
    sget-object v0, Lio/agora/base/internal/video/VideoCodecStatus;->OK:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object v0
.end method
.method public getImplementationName()Ljava/lang/String;
    .registers 2
    const-string v0, "HWDecoder"
    return-object v0
.end method
.method public getPrefersLateDecoding()Z
    .registers 2
    const/4 v0, 0x1
    return v0
.end method
.method public initDecode(Lio/agora/base/internal/video/VideoDecoder$Settings;Lio/agora/base/internal/video/VideoDecoder$Callback;)Lio/agora/base/internal/video/VideoCodecStatus;
    .registers 4
    .line 218
    iget-boolean v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->running:Z
    if-eqz v0, :cond_e
    const-string p1, "HardwareVideoDecoder"
    const-string p2, "already initialized!"
    .line 219
    invoke-static {p1, p2}, Lio/agora/base/internal/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
    .line 220
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->OK:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
    .line 223
    :cond_e
    iput-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->callback:Lio/agora/base/internal/video/VideoDecoder$Callback;
    .line 224
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->directSurface:Landroid/view/Surface;
    if-eqz p2, :cond_17
    .line 225
    iput-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surface:Landroid/view/Surface;
    goto :goto_38
    .line 226
    :cond_17
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->sharedContext:Lio/agora/base/internal/video/EglBase$Context;
    if-eqz p2, :cond_38
    .line 227
    invoke-virtual {p0}, Lio/agora/base/internal/video/HardwareVideoDecoder;->createSurfaceTextureHelper()Lio/agora/base/internal/video/SurfaceTextureHelper;
    move-result-object p2
    iput-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surfaceTextureHelper:Lio/agora/base/internal/video/SurfaceTextureHelper;
    if-nez p2, :cond_26
    .line 229
    sget-object p1, Lio/agora/base/internal/video/VideoCodecStatus;->FALLBACK_SOFTWARE:Lio/agora/base/internal/video/VideoCodecStatus;
    return-object p1
    .line 231
    :cond_26
    new-instance p2, Landroid/view/Surface;
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surfaceTextureHelper:Lio/agora/base/internal/video/SurfaceTextureHelper;
    invoke-virtual {v0}, Lio/agora/base/internal/video/SurfaceTextureHelper;->getSurfaceTexture()Landroid/graphics/SurfaceTexture;
    move-result-object v0
    invoke-direct {p2, v0}, Landroid/view/Surface;-><init>(Landroid/graphics/SurfaceTexture;)V
    iput-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surface:Landroid/view/Surface;
    .line 232
    iget-object p2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surfaceTextureHelper:Lio/agora/base/internal/video/SurfaceTextureHelper;
    invoke-virtual {p2, p0}, Lio/agora/base/internal/video/SurfaceTextureHelper;->startListening(Lio/agora/base/internal/video/VideoSink;)V
    .line 235
    :cond_38
    :goto_38
    iget p2, p1, Lio/agora/base/internal/video/VideoDecoder$Settings;->width:I
    iget p1, p1, Lio/agora/base/internal/video/VideoDecoder$Settings;->height:I
    invoke-direct {p0, p2, p1}, Lio/agora/base/internal/video/HardwareVideoDecoder;->initDecodeInternal(II)Lio/agora/base/internal/video/VideoCodecStatus;
    move-result-object p1
    return-object p1
.end method
.method public isHardwareDecoder()Z
    .registers 2
    const/4 v0, 0x1
    return v0
.end method
.method public onFrame(Lio/agora/base/VideoFrame;)V
    .registers 16
    .line 687
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->textureMetadataLock:Ljava/lang/Object;
    monitor-enter v0
    .line 688
    :try_start_3
    iget-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->renderedTextureMetadata:Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;
    if-eqz v1, :cond_165
    .line 692
    iget-wide v1, v1, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;->presentationTimestampUs:J
    .line 693
    iget-object v3, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->renderedTextureMetadata:Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;
    iget-wide v3, v3, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;->presentationTimestampUs:J
    const-wide/16 v5, 0x3e8
    mul-long/2addr v3, v5
    .line 694
    iget-object v5, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->renderedTextureMetadata:Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;
    iget-object v5, v5, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;->decodeTimeMs:Ljava/lang/Integer;
    invoke-virtual {v5}, Ljava/lang/Integer;->intValue()I
    move-result v5
    .line 695
    iget-object v6, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->codecSpecificInfoMap:Ljava/util/Map;
    iget-object v7, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->renderedTextureMetadata:Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;
    iget-wide v7, v7, Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;->presentationTimestampUs:J
    .line 696
    invoke-static {v7, v8}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
    move-result-object v7
    invoke-interface {v6, v7}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
    move-result-object v6
    move-object v13, v6
    check-cast v13, Lio/agora/base/internal/video/CodecSpecificInfo;
    const/4 v6, 0x0
    .line 697
    iput-object v6, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->renderedTextureMetadata:Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;
    .line 698
    invoke-direct {p0}, Lio/agora/base/internal/video/HardwareVideoDecoder;->maybeRenderDecodedTextureBuffer()V
    .line 699
    monitor-exit v0
    :try_end_30
    .catchall {:try_start_3 .. :try_end_30} :catchall_16d
    .line 701
    new-instance v0, Lio/agora/base/VideoFrame;
    .line 702
    invoke-virtual {p1}, Lio/agora/base/VideoFrame;->getBuffer()Lio/agora/base/VideoFrame$Buffer;
    move-result-object v7
    invoke-virtual {p1}, Lio/agora/base/VideoFrame;->getRotation()I
    move-result p1
    invoke-direct {v0, v7, p1, v3, v4}, Lio/agora/base/VideoFrame;-><init>(Lio/agora/base/VideoFrame$Buffer;IJ)V
    .line 705
    iget-object p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->decodeTimeStamps:Ljava/util/Queue;
    invoke-interface {p1}, Ljava/util/Queue;->size()I
    move-result v12
    .line 706
    :goto_43
    iget-object p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->decodeTimeStamps:Ljava/util/Queue;
    invoke-interface {p1}, Ljava/util/Queue;->isEmpty()Z
    move-result p1
    if-nez p1, :cond_81
    iget-object p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->decodeTimeStamps:Ljava/util/Queue;
    invoke-interface {p1}, Ljava/util/Queue;->poll()Ljava/lang/Object;
    move-result-object p1
    move-object v6, p1
    check-cast v6, Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;
    if-eqz v6, :cond_81
    .line 707
    # getter for: Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;->presentationTimeStampUs:J
    invoke-static {v6}, Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;->access$800(Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;)J
    move-result-wide v3
    cmp-long p1, v3, v1
    if-eqz p1, :cond_81
    const-string p1, "HardwareVideoDecoder"
    .line 708
    new-instance v3, Ljava/lang/StringBuilder;
    invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
    const-string v4, "decodeTimeStamps remove: "
    invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    .line 709
    # getter for: Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;->presentationTimeStampUs:J
    invoke-static {v6}, Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;->access$800(Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;)J
    move-result-wide v7
    invoke-virtual {v3, v7, v8}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
    const-string v4, " , cannot find presentationTimeUs: "
    invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v3, v1, v2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
    invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v3
    .line 708
    invoke-static {p1, v3}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    goto :goto_43
    :cond_81
    const/4 p1, -0x1
    const/16 v3, 0x7d0
    if-nez v6, :cond_9d
    const-string v3, "HardwareVideoDecoder"
    .line 714
    new-instance v4, Ljava/lang/StringBuilder;
    invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
    const-string v6, "decodeTimeStamps empty. cannot find: "
    invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v4, v1, v2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
    invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v4
    invoke-static {v3, v4}, Lio/agora/base/internal/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
    goto :goto_c6
    .line 716
    :cond_9d
    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
    move-result-wide v7
    # getter for: Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;->decodeStartTimeMs:J
    invoke-static {v6}, Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;->access$1400(Lio/agora/base/internal/video/HardwareVideoDecoder$TimeStamps;)J
    move-result-wide v9
    sub-long/2addr v7, v9
    long-to-int p1, v7
    if-le p1, v3, :cond_c6
    const-string v4, "HardwareVideoDecoder"
    .line 718
    new-instance v6, Ljava/lang/StringBuilder;
    invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
    const-string v7, "Very high decode time: "
    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v6, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    const-string p1, "ms."
    invoke-virtual {v6, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p1
    invoke-static {v4, p1}, Lio/agora/base/internal/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
    move v11, v3
    goto :goto_c7
    :cond_c6
    :goto_c6
    move v11, p1
    :goto_c7
    const/4 p1, 0x0
    if-eqz v13, :cond_eb
    .line 727
    invoke-virtual {v13}, Lio/agora/base/internal/video/CodecSpecificInfo;->getVideoCodecType()Lio/agora/base/internal/video/VideoCodecType;
    move-result-object v3
    sget-object v4, Lio/agora/base/internal/video/VideoCodecType;->H265:Lio/agora/base/internal/video/VideoCodecType;
    if-ne v3, v4, :cond_eb
    .line 728
    invoke-virtual {v13}, Lio/agora/base/internal/video/CodecSpecificInfo;->getVideoCodecProfile()Lio/agora/base/internal/video/VideoCodecProfile;
    move-result-object v3
    sget-object v4, Lio/agora/base/internal/video/VideoCodecProfile;->HEVCMain10:Lio/agora/base/internal/video/VideoCodecProfile;
    if-eq v3, v4, :cond_ea
    .line 729
    invoke-virtual {v13}, Lio/agora/base/internal/video/CodecSpecificInfo;->getVideoCodecProfile()Lio/agora/base/internal/video/VideoCodecProfile;
    move-result-object v3
    sget-object v4, Lio/agora/base/internal/video/VideoCodecProfile;->HEVCMain10HDR10:Lio/agora/base/internal/video/VideoCodecProfile;
    if-eq v3, v4, :cond_ea
    .line 730
    invoke-virtual {v13}, Lio/agora/base/internal/video/CodecSpecificInfo;->getVideoCodecProfile()Lio/agora/base/internal/video/VideoCodecProfile;
    move-result-object v3
    sget-object v4, Lio/agora/base/internal/video/VideoCodecProfile;->HEVCMain10HDR10Plus:Lio/agora/base/internal/video/VideoCodecProfile;
    if-ne v3, v4, :cond_eb
    :cond_ea
    const/4 p1, 0x1
    :cond_eb
    if-eqz p1, :cond_121
    .line 735
    new-instance p1, Lio/agora/base/VideoFrame;
    invoke-virtual {v0}, Lio/agora/base/VideoFrame;->getBuffer()Lio/agora/base/VideoFrame$Buffer;
    move-result-object v3
    .line 736
    invoke-virtual {v0}, Lio/agora/base/VideoFrame;->getRotation()I
    move-result v4
    invoke-virtual {v0}, Lio/agora/base/VideoFrame;->getTimestampNs()J
    move-result-wide v6
    invoke-direct {p1, v3, v4, v6, v7}, Lio/agora/base/VideoFrame;-><init>(Lio/agora/base/VideoFrame$Buffer;IJ)V
    .line 737
    iget-object v7, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->callback:Lio/agora/base/internal/video/VideoDecoder$Callback;
    invoke-static {v5}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
    move-result-object v9
    const/4 v10, 0x0
    move-object v8, p1
    invoke-interface/range {v7 .. v13}, Lio/agora/base/internal/video/VideoDecoder$Callback;->onDecodedFrame(Lio/agora/base/VideoFrame;Ljava/lang/Integer;Ljava/lang/Integer;IILio/agora/base/internal/video/CodecSpecificInfo;)V
    .line 739
    invoke-virtual {p1}, Lio/agora/base/VideoFrame;->release()V
    .line 740
    new-instance p1, Ljava/lang/StringBuilder;
    invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
    const-string v0, "frame delivered to native by direct oes, pts_us: "
    invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {p1, v1, v2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
    invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p1
    invoke-static {p1}, Lio/agora/base/internal/video/HardwareVideoDecoder;->debug_log(Ljava/lang/String;)V
    goto :goto_164
    .line 742
    :cond_121
    iget-object p1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surfaceTextureHelper:Lio/agora/base/internal/video/SurfaceTextureHelper;
    .line 743
    invoke-virtual {v0}, Lio/agora/base/VideoFrame;->getBuffer()Lio/agora/base/VideoFrame$Buffer;
    move-result-object v3
    check-cast v3, Lio/agora/base/VideoFrame$TextureBuffer;
    .line 742
    invoke-virtual {p1, v3}, Lio/agora/base/internal/video/SurfaceTextureHelper;->textureCopy(Lio/agora/base/VideoFrame$TextureBuffer;)Lio/agora/base/VideoFrame$TextureBuffer;
    move-result-object p1
    if-nez p1, :cond_135
    const-string p1, "failed to copy texture buffer, drop frame"
    .line 745
    invoke-static {p1}, Lio/agora/base/internal/video/HardwareVideoDecoder;->debug_log(Ljava/lang/String;)V
    goto :goto_164
    .line 747
    :cond_135
    new-instance v3, Lio/agora/base/VideoFrame;
    .line 748
    invoke-virtual {v0}, Lio/agora/base/VideoFrame;->getRotation()I
    move-result v4
    invoke-virtual {v0}, Lio/agora/base/VideoFrame;->getTimestampNs()J
    move-result-wide v6
    invoke-direct {v3, p1, v4, v6, v7}, Lio/agora/base/VideoFrame;-><init>(Lio/agora/base/VideoFrame$Buffer;IJ)V
    .line 749
    iget-object v7, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->callback:Lio/agora/base/internal/video/VideoDecoder$Callback;
    invoke-static {v5}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
    move-result-object v9
    const/4 v10, 0x0
    move-object v8, v3
    invoke-interface/range {v7 .. v13}, Lio/agora/base/internal/video/VideoDecoder$Callback;->onDecodedFrame(Lio/agora/base/VideoFrame;Ljava/lang/Integer;Ljava/lang/Integer;IILio/agora/base/internal/video/CodecSpecificInfo;)V
    .line 751
    invoke-virtual {v3}, Lio/agora/base/VideoFrame;->release()V
    .line 752
    new-instance p1, Ljava/lang/StringBuilder;
    invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
    const-string v0, "frame delivered to native, pts_us: "
    invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {p1, v1, v2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
    invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p1
    invoke-static {p1}, Lio/agora/base/internal/video/HardwareVideoDecoder;->debug_log(Ljava/lang/String;)V
    :goto_164
    return-void
    .line 689
    :cond_165
    :try_start_165
    new-instance p1, Ljava/lang/IllegalStateException;
    const-string v1, "Rendered texture metadata was null in onTextureFrameAvailable."
    invoke-direct {p1, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
    throw p1
    :catchall_16d
    move-exception p1
    .line 699
    monitor-exit v0
    :try_end_16f
    .catchall {:try_start_165 .. :try_end_16f} :catchall_16d
    throw p1
.end method
.method public release()Lio/agora/base/internal/video/VideoCodecStatus;
    .registers 4
    const-string v0, "HardwareVideoDecoder"
    const-string v1, "release"
    .line 519
    invoke-static {v0, v1}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    .line 520
    invoke-direct {p0}, Lio/agora/base/internal/video/HardwareVideoDecoder;->releaseInternal()Lio/agora/base/internal/video/VideoCodecStatus;
    move-result-object v0
    .line 521
    iget-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surface:Landroid/view/Surface;
    const/4 v2, 0x0
    if-eqz v1, :cond_25
    iget-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->directSurface:Landroid/view/Surface;
    if-nez v1, :cond_25
    .line 522
    invoke-virtual {p0}, Lio/agora/base/internal/video/HardwareVideoDecoder;->releaseSurface()V
    .line 523
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surface:Landroid/view/Surface;
    .line 524
    iget-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surfaceTextureHelper:Lio/agora/base/internal/video/SurfaceTextureHelper;
    invoke-virtual {v1}, Lio/agora/base/internal/video/SurfaceTextureHelper;->stopListening()V
    .line 525
    iget-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surfaceTextureHelper:Lio/agora/base/internal/video/SurfaceTextureHelper;
    invoke-virtual {v1}, Lio/agora/base/internal/video/SurfaceTextureHelper;->dispose()V
    .line 526
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surfaceTextureHelper:Lio/agora/base/internal/video/SurfaceTextureHelper;
    .line 528
    :cond_25
    iget-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->textureMetadataLock:Ljava/lang/Object;
    monitor-enter v1
    .line 529
    :try_start_28
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->renderedTextureMetadata:Lio/agora/base/internal/video/HardwareVideoDecoder$DecodedTextureMetadata;
    .line 530
    monitor-exit v1
    :try_end_2b
    .catchall {:try_start_28 .. :try_end_2b} :catchall_38
    .line 531
    iput-object v2, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->callback:Lio/agora/base/internal/video/VideoDecoder$Callback;
    .line 532
    iget-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->frameInfos:Ljava/util/concurrent/BlockingDeque;
    invoke-interface {v1}, Ljava/util/concurrent/BlockingDeque;->clear()V
    .line 533
    iget-object v1, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->decodeTimeStamps:Ljava/util/Queue;
    invoke-interface {v1}, Ljava/util/Queue;->clear()V
    return-object v0
    :catchall_38
    move-exception v0
    .line 530
    :try_start_39
    monitor-exit v1
    :try_end_3a
    .catchall {:try_start_39 .. :try_end_3a} :catchall_38
    throw v0
.end method
.method protected releaseSurface()V
    .registers 2
    .line 1060
    iget-object v0, p0, Lio/agora/base/internal/video/HardwareVideoDecoder;->surface:Landroid/view/Surface;
    invoke-virtual {v0}, Landroid/view/Surface;->release()V
    return-void
.end method