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