HardwareVideoEncoder.smali
.class Lorg/webrtc/ali/HardwareVideoEncoder;
.super Ljava/lang/Object;
.source "HardwareVideoEncoder.java"
# interfaces
.implements Lorg/webrtc/ali/VideoEncoder;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;
}
.end annotation
# static fields
.field private static final DEQUEUE_OUTPUT_BUFFER_TIMEOUT_US:I
.field private static final KEY_BITRATE_MODE:Ljava/lang/String; = "bitrate-mode"
.field private static final MAX_ENCODER_Q_SIZE:I
.field private static final MAX_VIDEO_FRAMERATE:I
.field private static final MEDIA_CODEC_RELEASE_TIMEOUT_MS:I
.field private static final TAG:Ljava/lang/String; = "HardwareVideoEncoder"
.field private static final VIDEO_ControlRateConstant:I
# instance fields
.field private adjustedBitrate:I
.field private final bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;
.field private callback:Lorg/webrtc/ali/VideoEncoder$Callback;
.field private codec:Landroid/media/MediaCodec;
.field private final codecName:Ljava/lang/String;
.field private final codecType:Lorg/webrtc/ali/VideoCodecType;
.field private final colorFormat:I
.field private configBuffer:Ljava/nio/ByteBuffer;
.field private final forcedKeyFrameMs:J
.field private height:I
.field private final inputColorFormat:Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;
.field private final keyFrameIntervalSec:I
.field private lastKeyFrameMs:J
.field private final outputBuilders:Ljava/util/Deque;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Deque<",
"Lorg/webrtc/ali/EncodedImage$Builder;",
">;"
}
.end annotation
.end field
.field private outputThread:Ljava/lang/Thread;
.field private volatile running:Z
.field private volatile shutdownException:Ljava/lang/Exception;
.field private width:I
# direct methods
.method static constructor <clinit>()V
.registers 1
const v0, 0x193cf
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lorg/webrtc/ali/HardwareVideoEncoder;->DEQUEUE_OUTPUT_BUFFER_TIMEOUT_US:I
const v0, 0x156d
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lorg/webrtc/ali/HardwareVideoEncoder;->MAX_ENCODER_Q_SIZE:I
const v0, 0x1571
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lorg/webrtc/ali/HardwareVideoEncoder;->MAX_VIDEO_FRAMERATE:I
const v0, 0x6e7
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lorg/webrtc/ali/HardwareVideoEncoder;->MEDIA_CODEC_RELEASE_TIMEOUT_MS:I
const v0, 0x156d
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lorg/webrtc/ali/HardwareVideoEncoder;->VIDEO_ControlRateConstant:I
return-void
.end method
.method public constructor <init>(Ljava/lang/String;Lorg/webrtc/ali/VideoCodecType;IIILorg/webrtc/ali/BitrateAdjuster;)V
.registers 9
.param p1, "codecName" # Ljava/lang/String;
.param p2, "codecType" # Lorg/webrtc/ali/VideoCodecType;
.param p3, "colorFormat" # I
.param p4, "keyFrameIntervalSec" # I
.param p5, "forceKeyFrameIntervalMs" # I
.param p6, "bitrateAdjuster" # Lorg/webrtc/ali/BitrateAdjuster;
.line 100
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 71
const/4 v0, 0x0
iput-boolean v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->running:Z
.line 74
const/4 v0, 0x0
iput-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->shutdownException:Ljava/lang/Exception;
.line 83
iput-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->configBuffer:Ljava/nio/ByteBuffer;
.line 101
iput-object p1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecName:Ljava/lang/String;
.line 102
iput-object p2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecType:Lorg/webrtc/ali/VideoCodecType;
.line 103
iput p3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->colorFormat:I
.line 104
invoke-static {p3}, Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;->valueOf(I)Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;
move-result-object v0
iput-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->inputColorFormat:Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;
.line 105
iput p4, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->keyFrameIntervalSec:I
.line 106
int-to-long v0, p5
iput-wide v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->forcedKeyFrameMs:J
.line 107
iput-object p6, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;
.line 108
new-instance v0, Ljava/util/concurrent/LinkedBlockingDeque;
invoke-direct {v0}, Ljava/util/concurrent/LinkedBlockingDeque;-><init>()V
iput-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;
.line 109
return-void
.end method
.method static synthetic access$000(Lorg/webrtc/ali/HardwareVideoEncoder;)Z
.registers 2
.param p0, "x0" # Lorg/webrtc/ali/HardwareVideoEncoder;
.line 29
iget-boolean v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->running:Z
return v0
.end method
.method static synthetic access$100(Lorg/webrtc/ali/HardwareVideoEncoder;)V
.registers 1
.param p0, "x0" # Lorg/webrtc/ali/HardwareVideoEncoder;
.line 29
invoke-direct {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->deliverEncodedImage()V
return-void
.end method
.method static synthetic access$200(Lorg/webrtc/ali/HardwareVideoEncoder;)V
.registers 1
.param p0, "x0" # Lorg/webrtc/ali/HardwareVideoEncoder;
.line 29
invoke-direct {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->releaseCodecOnOutputThread()V
return-void
.end method
.method private createOutputThread()Ljava/lang/Thread;
.registers 2
.line 323
new-instance v0, Lorg/webrtc/ali/HardwareVideoEncoder$1;
invoke-direct {v0, p0}, Lorg/webrtc/ali/HardwareVideoEncoder$1;-><init>(Lorg/webrtc/ali/HardwareVideoEncoder;)V
return-object v0
.end method
.method private deliverEncodedImage()V
.registers 13
.line 336
const-string v0, "HardwareVideoEncoder"
:try_start_2
new-instance v1, Landroid/media/MediaCodec$BufferInfo;
invoke-direct {v1}, Landroid/media/MediaCodec$BufferInfo;-><init>()V
.line 337
.local v1, "info":Landroid/media/MediaCodec$BufferInfo;
iget-object v2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
const-wide/32 v3, 0x186a0
invoke-virtual {v2, v1, v3, v4}, Landroid/media/MediaCodec;->dequeueOutputBuffer(Landroid/media/MediaCodec$BufferInfo;J)I
move-result v2
.line 338
.local v2, "index":I
if-gez v2, :cond_13
.line 339
return-void
.line 342
:cond_13
iget-object v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
invoke-virtual {v3}, Landroid/media/MediaCodec;->getOutputBuffers()[Ljava/nio/ByteBuffer;
move-result-object v3
aget-object v3, v3, v2
.line 343
.local v3, "codecOutputBuffer":Ljava/nio/ByteBuffer;
iget v4, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I
invoke-virtual {v3, v4}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
.line 344
iget v4, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I
iget v5, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
add-int/2addr v4, v5
invoke-virtual {v3, v4}, Ljava/nio/ByteBuffer;->limit(I)Ljava/nio/Buffer;
.line 346
iget v4, v1, Landroid/media/MediaCodec$BufferInfo;->flags:I
and-int/lit8 v4, v4, 0x2
const/4 v5, 0x0
if-eqz v4, :cond_5c
.line 347
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "Config frame generated. Offset: "
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v6, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v6, ". Size: "
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v6, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-static {v0, v4}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 348
iget v4, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
invoke-static {v4}, Ljava/nio/ByteBuffer;->allocateDirect(I)Ljava/nio/ByteBuffer;
move-result-object v4
iput-object v4, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->configBuffer:Ljava/nio/ByteBuffer;
.line 349
invoke-virtual {v4, v3}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
goto/16 :goto_fc
.line 351
:cond_5c
iget-object v4, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;
iget v6, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
invoke-interface {v4, v6}, Lorg/webrtc/ali/BitrateAdjuster;->reportEncodedFrame(I)V
.line 352
iget v4, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->adjustedBitrate:I
iget-object v6, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;
invoke-interface {v6}, Lorg/webrtc/ali/BitrateAdjuster;->getAdjustedBitrateBps()I
move-result v6
if-eq v4, v6, :cond_70
.line 353
invoke-direct {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->updateBitrate()Lorg/webrtc/ali/VideoCodecStatus;
.line 357
:cond_70
iget v4, v1, Landroid/media/MediaCodec$BufferInfo;->flags:I
const/4 v6, 0x1
and-int/2addr v4, v6
if-eqz v4, :cond_77
goto :goto_78
:cond_77
const/4 v6, 0x0
:goto_78
move v4, v6
.line 358
.local v4, "isKeyFrame":Z
if-eqz v4, :cond_c7
iget-object v6, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecType:Lorg/webrtc/ali/VideoCodecType;
sget-object v7, Lorg/webrtc/ali/VideoCodecType;->H264:Lorg/webrtc/ali/VideoCodecType;
if-ne v6, v7, :cond_c7
.line 359
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, "Prepending config frame of size "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v7, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->configBuffer:Ljava/nio/ByteBuffer;
.line 360
invoke-virtual {v7}, Ljava/nio/ByteBuffer;->capacity()I
move-result v7
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v7, " to output buffer with offset "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v7, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v7, ", size "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v7, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
.line 359
invoke-static {v0, v6}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 363
iget v6, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
iget-object v7, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->configBuffer:Ljava/nio/ByteBuffer;
invoke-virtual {v7}, Ljava/nio/ByteBuffer;->capacity()I
move-result v7
add-int/2addr v6, v7
invoke-static {v6}, Ljava/nio/ByteBuffer;->allocateDirect(I)Ljava/nio/ByteBuffer;
move-result-object v6
.line 364
.local v6, "frameBuffer":Ljava/nio/ByteBuffer;
iget-object v7, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->configBuffer:Ljava/nio/ByteBuffer;
invoke-virtual {v7}, Ljava/nio/ByteBuffer;->rewind()Ljava/nio/Buffer;
.line 365
iget-object v7, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->configBuffer:Ljava/nio/ByteBuffer;
invoke-virtual {v6, v7}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
goto :goto_cd
.line 367
.end local v6 # "frameBuffer":Ljava/nio/ByteBuffer;
:cond_c7
iget v6, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
invoke-static {v6}, Ljava/nio/ByteBuffer;->allocateDirect(I)Ljava/nio/ByteBuffer;
move-result-object v6
.line 369
.restart local v6 # "frameBuffer":Ljava/nio/ByteBuffer;
:goto_cd
invoke-virtual {v6, v3}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
.line 370
invoke-virtual {v6}, Ljava/nio/ByteBuffer;->rewind()Ljava/nio/Buffer;
.line 372
sget-object v7, Lorg/webrtc/ali/EncodedImage$FrameType;->VideoFrameDelta:Lorg/webrtc/ali/EncodedImage$FrameType;
.line 373
.local v7, "frameType":Lorg/webrtc/ali/EncodedImage$FrameType;
if-eqz v4, :cond_df
.line 374
const-string v8, "Sync frame generated"
invoke-static {v0, v8}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 375
sget-object v8, Lorg/webrtc/ali/EncodedImage$FrameType;->VideoFrameKey:Lorg/webrtc/ali/EncodedImage$FrameType;
move-object v7, v8
.line 377
:cond_df
iget-object v8, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;
invoke-interface {v8}, Ljava/util/Deque;->poll()Ljava/lang/Object;
move-result-object v8
check-cast v8, Lorg/webrtc/ali/EncodedImage$Builder;
.line 378
.local v8, "builder":Lorg/webrtc/ali/EncodedImage$Builder;
invoke-virtual {v8, v6}, Lorg/webrtc/ali/EncodedImage$Builder;->setBuffer(Ljava/nio/ByteBuffer;)Lorg/webrtc/ali/EncodedImage$Builder;
move-result-object v9
invoke-virtual {v9, v7}, Lorg/webrtc/ali/EncodedImage$Builder;->setFrameType(Lorg/webrtc/ali/EncodedImage$FrameType;)Lorg/webrtc/ali/EncodedImage$Builder;
.line 380
iget-object v9, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->callback:Lorg/webrtc/ali/VideoEncoder$Callback;
invoke-virtual {v8}, Lorg/webrtc/ali/EncodedImage$Builder;->createEncodedImage()Lorg/webrtc/ali/EncodedImage;
move-result-object v10
new-instance v11, Lorg/webrtc/ali/VideoEncoder$CodecSpecificInfo;
invoke-direct {v11}, Lorg/webrtc/ali/VideoEncoder$CodecSpecificInfo;-><init>()V
invoke-interface {v9, v10, v11}, Lorg/webrtc/ali/VideoEncoder$Callback;->onEncodedFrame(Lorg/webrtc/ali/EncodedImage;Lorg/webrtc/ali/VideoEncoder$CodecSpecificInfo;)V
.line 382
.end local v4 # "isKeyFrame":Z
.end local v6 # "frameBuffer":Ljava/nio/ByteBuffer;
.end local v7 # "frameType":Lorg/webrtc/ali/EncodedImage$FrameType;
.end local v8 # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
:goto_fc
iget-object v4, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
invoke-virtual {v4, v2, v5}, Landroid/media/MediaCodec;->releaseOutputBuffer(IZ)V
:try_end_101
.catch Ljava/lang/IllegalStateException; {:try_start_2 .. :try_end_101} :catch_102
.line 385
.end local v1 # "info":Landroid/media/MediaCodec$BufferInfo;
.end local v2 # "index":I
.end local v3 # "codecOutputBuffer":Ljava/nio/ByteBuffer;
goto :goto_108
.line 383
:catch_102
move-exception v1
.line 384
.local v1, "e":Ljava/lang/IllegalStateException;
const-string v2, "deliverOutput failed"
invoke-static {v0, v2, v1}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 386
.end local v1 # "e":Ljava/lang/IllegalStateException;
:goto_108
return-void
.end method
.method private initEncodeInternal(IIIILorg/webrtc/ali/VideoEncoder$Callback;)Lorg/webrtc/ali/VideoCodecStatus;
.registers 11
.param p1, "width" # I
.param p2, "height" # I
.param p3, "bitrateKbps" # I
.param p4, "fps" # I
.param p5, "callback" # Lorg/webrtc/ali/VideoEncoder$Callback;
.line 119
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "initEncode: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, " x "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, ". @ "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, "kbps. Fps: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
const-string v1, "HardwareVideoEncoder"
invoke-static {v1, v0}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 121
iput p1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->width:I
.line 122
iput p2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->height:I
.line 123
if-eqz p3, :cond_3d
if-eqz p4, :cond_3d
.line 124
iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;
mul-int/lit16 v2, p3, 0x3e8
invoke-interface {v0, v2, p4}, Lorg/webrtc/ali/BitrateAdjuster;->setTargets(II)V
.line 126
:cond_3d
iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;
invoke-interface {v0}, Lorg/webrtc/ali/BitrateAdjuster;->getAdjustedBitrateBps()I
move-result v0
iput v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->adjustedBitrate:I
.line 128
iput-object p5, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->callback:Lorg/webrtc/ali/VideoEncoder$Callback;
.line 130
const-wide/16 v2, -0x1
iput-wide v2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->lastKeyFrameMs:J
.line 133
:try_start_4b
iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecName:Ljava/lang/String;
invoke-static {v0}, Landroid/media/MediaCodec;->createByCodecName(Ljava/lang/String;)Landroid/media/MediaCodec;
move-result-object v0
iput-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
:try_end_53
.catch Ljava/io/IOException; {:try_start_4b .. :try_end_53} :catch_c1
.catch Ljava/lang/IllegalArgumentException; {:try_start_4b .. :try_end_53} :catch_bf
.line 137
nop
.line 139
:try_start_54
iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecType:Lorg/webrtc/ali/VideoCodecType;
invoke-virtual {v0}, Lorg/webrtc/ali/VideoCodecType;->mimeType()Ljava/lang/String;
move-result-object v0
invoke-static {v0, p1, p2}, Landroid/media/MediaFormat;->createVideoFormat(Ljava/lang/String;II)Landroid/media/MediaFormat;
move-result-object v0
.line 140
.local v0, "format":Landroid/media/MediaFormat;
const-string v2, "bitrate"
iget v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->adjustedBitrate:I
invoke-virtual {v0, v2, v3}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V
.line 141
const-string v2, "bitrate-mode"
const/4 v3, 0x2
invoke-virtual {v0, v2, v3}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V
.line 142
const-string v2, "color-format"
iget v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->colorFormat:I
invoke-virtual {v0, v2, v3}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V
.line 143
const-string v2, "frame-rate"
iget-object v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;
invoke-interface {v3}, Lorg/webrtc/ali/BitrateAdjuster;->getAdjustedFramerate()I
move-result v3
invoke-virtual {v0, v2, v3}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V
.line 144
const-string v2, "i-frame-interval"
iget v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->keyFrameIntervalSec:I
invoke-virtual {v0, v2, v3}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V
.line 145
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Format: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v1, v2}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 146
iget-object v2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
const/4 v3, 0x1
const/4 v4, 0x0
invoke-virtual {v2, v0, v4, v4, v3}, Landroid/media/MediaCodec;->configure(Landroid/media/MediaFormat;Landroid/view/Surface;Landroid/media/MediaCrypto;I)V
.line 147
iget-object v2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
invoke-virtual {v2}, Landroid/media/MediaCodec;->start()V
:try_end_a4
.catch Ljava/lang/IllegalStateException; {:try_start_54 .. :try_end_a4} :catch_b3
.line 152
.end local v0 # "format":Landroid/media/MediaFormat;
nop
.line 154
iput-boolean v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->running:Z
.line 155
invoke-direct {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->createOutputThread()Ljava/lang/Thread;
move-result-object v0
iput-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputThread:Ljava/lang/Thread;
.line 156
invoke-virtual {v0}, Ljava/lang/Thread;->start()V
.line 158
sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;
return-object v0
.line 148
:catch_b3
move-exception v0
.line 149
.local v0, "e":Ljava/lang/IllegalStateException;
const-string v2, "initEncode failed"
invoke-static {v1, v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 150
invoke-virtual {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->release()Lorg/webrtc/ali/VideoCodecStatus;
.line 151
sget-object v1, Lorg/webrtc/ali/VideoCodecStatus;->ERROR:Lorg/webrtc/ali/VideoCodecStatus;
return-object v1
.line 134
.end local v0 # "e":Ljava/lang/IllegalStateException;
:catch_bf
move-exception v0
goto :goto_c2
:catch_c1
move-exception v0
.line 135
.local v0, "e":Ljava/lang/Exception;
:goto_c2
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Cannot create media encoder "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecName:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v1, v2}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 136
sget-object v1, Lorg/webrtc/ali/VideoCodecStatus;->ERROR:Lorg/webrtc/ali/VideoCodecStatus;
return-object v1
.end method
.method private releaseCodecOnOutputThread()V
.registers 4
.line 389
const-string v0, "HardwareVideoEncoder"
const-string v1, "Releasing MediaCodec on output thread"
invoke-static {v0, v1}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 391
:try_start_7
iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
invoke-virtual {v1}, Landroid/media/MediaCodec;->stop()V
:try_end_c
.catch Ljava/lang/Exception; {:try_start_7 .. :try_end_c} :catch_d
.line 394
goto :goto_13
.line 392
:catch_d
move-exception v1
.line 393
.local v1, "e":Ljava/lang/Exception;
const-string v2, "Media encoder stop failed"
invoke-static {v0, v2, v1}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 396
.end local v1 # "e":Ljava/lang/Exception;
:goto_13
:try_start_13
iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
invoke-virtual {v1}, Landroid/media/MediaCodec;->release()V
:try_end_18
.catch Ljava/lang/Exception; {:try_start_13 .. :try_end_18} :catch_19
.line 401
goto :goto_21
.line 397
:catch_19
move-exception v1
.line 398
.restart local v1 # "e":Ljava/lang/Exception;
const-string v2, "Media encoder release failed"
invoke-static {v0, v2, v1}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 400
iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->shutdownException:Ljava/lang/Exception;
.line 402
.end local v1 # "e":Ljava/lang/Exception;
:goto_21
const-string v1, "Release on output thread done"
invoke-static {v0, v1}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 403
return-void
.end method
.method private requestKeyFrame(J)V
.registers 6
.param p1, "presentationTimestampMs" # J
.line 312
:try_start_0
new-instance v0, Landroid/os/Bundle;
invoke-direct {v0}, Landroid/os/Bundle;-><init>()V
.line 313
.local v0, "b":Landroid/os/Bundle;
const-string v1, "request-sync"
const/4 v2, 0x0
invoke-virtual {v0, v1, v2}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V
.line 314
iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
invoke-virtual {v1, v0}, Landroid/media/MediaCodec;->setParameters(Landroid/os/Bundle;)V
:try_end_10
.catch Ljava/lang/IllegalStateException; {:try_start_0 .. :try_end_10} :catch_14
.line 318
.end local v0 # "b":Landroid/os/Bundle;
nop
.line 319
iput-wide p1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->lastKeyFrameMs:J
.line 320
return-void
.line 315
:catch_14
move-exception v0
.line 316
.local v0, "e":Ljava/lang/IllegalStateException;
const-string v1, "HardwareVideoEncoder"
const-string v2, "requestKeyFrame failed"
invoke-static {v1, v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 317
return-void
.end method
.method private resetCodec(II)Lorg/webrtc/ali/VideoCodecStatus;
.registers 11
.param p1, "newWidth" # I
.param p2, "newHeight" # I
.line 294
invoke-virtual {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->release()Lorg/webrtc/ali/VideoCodecStatus;
move-result-object v0
.line 295
.local v0, "status":Lorg/webrtc/ali/VideoCodecStatus;
sget-object v1, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;
if-eq v0, v1, :cond_9
.line 296
return-object v0
.line 299
:cond_9
const/4 v5, 0x0
const/4 v6, 0x0
iget-object v7, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->callback:Lorg/webrtc/ali/VideoEncoder$Callback;
move-object v2, p0
move v3, p1
move v4, p2
invoke-direct/range {v2 .. v7}, Lorg/webrtc/ali/HardwareVideoEncoder;->initEncodeInternal(IIIILorg/webrtc/ali/VideoEncoder$Callback;)Lorg/webrtc/ali/VideoCodecStatus;
move-result-object v1
return-object v1
.end method
.method private shouldForceKeyFrame(J)Z
.registers 8
.param p1, "presentationTimestampMs" # J
.line 303
iget-wide v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->forcedKeyFrameMs:J
const-wide/16 v2, 0x0
cmp-long v4, v0, v2
if-lez v4, :cond_11
iget-wide v2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->lastKeyFrameMs:J
add-long/2addr v2, v0
cmp-long v0, p1, v2
if-lez v0, :cond_11
const/4 v0, 0x1
goto :goto_12
:cond_11
const/4 v0, 0x0
:goto_12
return v0
.end method
.method private updateBitrate()Lorg/webrtc/ali/VideoCodecStatus;
.registers 4
.line 406
iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;
invoke-interface {v0}, Lorg/webrtc/ali/BitrateAdjuster;->getAdjustedBitrateBps()I
move-result v0
iput v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->adjustedBitrate:I
.line 408
:try_start_8
new-instance v0, Landroid/os/Bundle;
invoke-direct {v0}, Landroid/os/Bundle;-><init>()V
.line 409
.local v0, "params":Landroid/os/Bundle;
const-string v1, "video-bitrate"
iget v2, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->adjustedBitrate:I
invoke-virtual {v0, v1, v2}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V
.line 410
iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
invoke-virtual {v1, v0}, Landroid/media/MediaCodec;->setParameters(Landroid/os/Bundle;)V
.line 411
sget-object v1, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;
:try_end_1b
.catch Ljava/lang/IllegalStateException; {:try_start_8 .. :try_end_1b} :catch_1c
return-object v1
.line 412
.end local v0 # "params":Landroid/os/Bundle;
:catch_1c
move-exception v0
.line 413
.local v0, "e":Ljava/lang/IllegalStateException;
const-string v1, "HardwareVideoEncoder"
const-string v2, "updateBitrate failed"
invoke-static {v1, v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 414
sget-object v1, Lorg/webrtc/ali/VideoCodecStatus;->ERROR:Lorg/webrtc/ali/VideoCodecStatus;
return-object v1
.end method
# virtual methods
.method public encode(Lorg/webrtc/ali/VideoFrame;Lorg/webrtc/ali/VideoEncoder$EncodeInfo;)Lorg/webrtc/ali/VideoCodecStatus;
.registers 26
.param p1, "videoFrame" # Lorg/webrtc/ali/VideoFrame;
.param p2, "encodeInfo" # Lorg/webrtc/ali/VideoEncoder$EncodeInfo;
.line 185
move-object/from16 v1, p0
const-string v2, "HardwareVideoEncoder"
iget-object v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
if-nez v0, :cond_b
.line 186
sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->UNINITIALIZED:Lorg/webrtc/ali/VideoCodecStatus;
return-object v0
.line 190
:cond_b
invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getWidth()I
move-result v3
.line 191
.local v3, "frameWidth":I
invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getHeight()I
move-result v4
.line 192
.local v4, "frameHeight":I
iget v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->width:I
if-ne v3, v0, :cond_1b
iget v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->height:I
if-eq v4, v0, :cond_24
.line 193
:cond_1b
invoke-direct {v1, v3, v4}, Lorg/webrtc/ali/HardwareVideoEncoder;->resetCodec(II)Lorg/webrtc/ali/VideoCodecStatus;
move-result-object v0
.line 194
.local v0, "status":Lorg/webrtc/ali/VideoCodecStatus;
sget-object v5, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;
if-eq v0, v5, :cond_24
.line 195
return-object v0
.line 202
.end local v0 # "status":Lorg/webrtc/ali/VideoCodecStatus;
:cond_24
:try_start_24
iget-object v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
const-wide/16 v5, 0x0
invoke-virtual {v0, v5, v6}, Landroid/media/MediaCodec;->dequeueInputBuffer(J)I
move-result v0
:try_end_2c
.catch Ljava/lang/IllegalStateException; {:try_start_24 .. :try_end_2c} :catch_106
move v12, v0
.line 206
.local v12, "index":I
nop
.line 208
const/4 v0, -0x1
if-ne v12, v0, :cond_39
.line 210
const-string v0, "Dropped frame, no input buffers available"
invoke-static {v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 211
sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;
return-object v0
.line 213
:cond_39
iget-object v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;
invoke-interface {v0}, Ljava/util/Deque;->size()I
move-result v0
const/4 v5, 0x2
if-le v0, v5, :cond_4a
.line 215
const-string v0, "Dropped frame, encoder queue full"
invoke-static {v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 216
sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;
return-object v0
.line 222
:cond_4a
:try_start_4a
iget-object v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
invoke-virtual {v0}, Landroid/media/MediaCodec;->getInputBuffers()[Ljava/nio/ByteBuffer;
move-result-object v0
aget-object v0, v0, v12
:try_end_52
.catch Ljava/lang/IllegalStateException; {:try_start_4a .. :try_end_52} :catch_fb
move-object v13, v0
.line 226
.local v13, "buffer":Ljava/nio/ByteBuffer;
nop
.line 227
invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getBuffer()Lorg/webrtc/ali/VideoFrame$Buffer;
move-result-object v0
invoke-interface {v0}, Lorg/webrtc/ali/VideoFrame$Buffer;->toI420()Lorg/webrtc/ali/VideoFrame$I420Buffer;
move-result-object v14
.line 228
.local v14, "i420":Lorg/webrtc/ali/VideoFrame$I420Buffer;
iget-object v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->inputColorFormat:Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;
invoke-virtual {v0, v13, v14}, Lorg/webrtc/ali/HardwareVideoEncoder$ColorFormat;->fillBufferFromI420(Ljava/nio/ByteBuffer;Lorg/webrtc/ali/VideoFrame$I420Buffer;)V
.line 230
const/4 v0, 0x0
.line 231
.local v0, "requestedKeyFrame":Z
move-object/from16 v15, p2
iget-object v6, v15, Lorg/webrtc/ali/VideoEncoder$EncodeInfo;->frameTypes:[Lorg/webrtc/ali/EncodedImage$FrameType;
array-length v7, v6
const/4 v8, 0x0
move/from16 v16, v0
.end local v0 # "requestedKeyFrame":Z
.local v16, "requestedKeyFrame":Z
:goto_6a
if-ge v8, v7, :cond_78
aget-object v0, v6, v8
.line 232
.local v0, "frameType":Lorg/webrtc/ali/EncodedImage$FrameType;
sget-object v9, Lorg/webrtc/ali/EncodedImage$FrameType;->VideoFrameKey:Lorg/webrtc/ali/EncodedImage$FrameType;
if-ne v0, v9, :cond_75
.line 233
const/4 v9, 0x1
move/from16 v16, v9
.line 231
.end local v0 # "frameType":Lorg/webrtc/ali/EncodedImage$FrameType;
:cond_75
add-int/lit8 v8, v8, 0x1
goto :goto_6a
.line 238
:cond_78
invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getTimestampNs()J
move-result-wide v6
const-wide/16 v8, 0x1f4
add-long/2addr v6, v8
const-wide/16 v10, 0x3e8
div-long v17, v6, v10
.line 239
.local v17, "presentationTimestampUs":J
add-long v8, v17, v8
div-long v9, v8, v10
.line 240
.local v9, "presentationTimestampMs":J
if-nez v16, :cond_8f
invoke-direct {v1, v9, v10}, Lorg/webrtc/ali/HardwareVideoEncoder;->shouldForceKeyFrame(J)Z
move-result v0
if-eqz v0, :cond_92
.line 241
:cond_8f
invoke-direct {v1, v9, v10}, Lorg/webrtc/ali/HardwareVideoEncoder;->requestKeyFrame(J)V
.line 246
:cond_92
invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getBuffer()Lorg/webrtc/ali/VideoFrame$Buffer;
move-result-object v0
invoke-interface {v0}, Lorg/webrtc/ali/VideoFrame$Buffer;->getHeight()I
move-result v0
invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getBuffer()Lorg/webrtc/ali/VideoFrame$Buffer;
move-result-object v6
invoke-interface {v6}, Lorg/webrtc/ali/VideoFrame$Buffer;->getWidth()I
move-result v6
mul-int v0, v0, v6
mul-int/lit8 v0, v0, 0x3
div-int/lit8 v19, v0, 0x2
.line 247
.local v19, "bufferSize":I
invoke-static {}, Lorg/webrtc/ali/EncodedImage;->builder()Lorg/webrtc/ali/EncodedImage$Builder;
move-result-object v0
.line 248
invoke-virtual {v0, v9, v10}, Lorg/webrtc/ali/EncodedImage$Builder;->setCaptureTimeMs(J)Lorg/webrtc/ali/EncodedImage$Builder;
move-result-object v0
.line 249
const/4 v5, 0x1
invoke-virtual {v0, v5}, Lorg/webrtc/ali/EncodedImage$Builder;->setCompleteFrame(Z)Lorg/webrtc/ali/EncodedImage$Builder;
move-result-object v0
.line 250
invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getWidth()I
move-result v5
invoke-virtual {v0, v5}, Lorg/webrtc/ali/EncodedImage$Builder;->setEncodedWidth(I)Lorg/webrtc/ali/EncodedImage$Builder;
move-result-object v0
.line 251
invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getHeight()I
move-result v5
invoke-virtual {v0, v5}, Lorg/webrtc/ali/EncodedImage$Builder;->setEncodedHeight(I)Lorg/webrtc/ali/EncodedImage$Builder;
move-result-object v0
.line 252
invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoFrame;->getRotation()I
move-result v5
invoke-virtual {v0, v5}, Lorg/webrtc/ali/EncodedImage$Builder;->setRotation(I)Lorg/webrtc/ali/EncodedImage$Builder;
move-result-object v11
.line 253
.local v11, "builder":Lorg/webrtc/ali/EncodedImage$Builder;
iget-object v0, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;
invoke-interface {v0, v11}, Ljava/util/Deque;->offer(Ljava/lang/Object;)Z
.line 255
:try_start_d2
iget-object v5, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
:try_end_d4
.catch Ljava/lang/IllegalStateException; {:try_start_d2 .. :try_end_d4} :catch_e9
const/4 v7, 0x0
const/4 v0, 0x0
move v6, v12
move/from16 v8, v19
move-wide/from16 v20, v9
.end local v9 # "presentationTimestampMs":J
.local v20, "presentationTimestampMs":J
move-wide/from16 v9, v17
move-object/from16 v22, v11
.end local v11 # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
.local v22, "builder":Lorg/webrtc/ali/EncodedImage$Builder;
move v11, v0
:try_start_e0
invoke-virtual/range {v5 .. v11}, Landroid/media/MediaCodec;->queueInputBuffer(IIIJI)V
:try_end_e3
.catch Ljava/lang/IllegalStateException; {:try_start_e0 .. :try_end_e3} :catch_e7
.line 263
nop
.line 264
sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;
return-object v0
.line 257
:catch_e7
move-exception v0
goto :goto_ee
.end local v20 # "presentationTimestampMs":J
.end local v22 # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
.restart local v9 # "presentationTimestampMs":J
.restart local v11 # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
:catch_e9
move-exception v0
move-wide/from16 v20, v9
move-object/from16 v22, v11
.line 258
.end local v9 # "presentationTimestampMs":J
.end local v11 # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
.local v0, "e":Ljava/lang/IllegalStateException;
.restart local v20 # "presentationTimestampMs":J
.restart local v22 # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
:goto_ee
const-string v5, "queueInputBuffer failed"
invoke-static {v2, v5, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 260
iget-object v2, v1, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;
invoke-interface {v2}, Ljava/util/Deque;->pollLast()Ljava/lang/Object;
.line 262
sget-object v2, Lorg/webrtc/ali/VideoCodecStatus;->FALLBACK_SOFTWARE:Lorg/webrtc/ali/VideoCodecStatus;
return-object v2
.line 223
.end local v0 # "e":Ljava/lang/IllegalStateException;
.end local v13 # "buffer":Ljava/nio/ByteBuffer;
.end local v14 # "i420":Lorg/webrtc/ali/VideoFrame$I420Buffer;
.end local v16 # "requestedKeyFrame":Z
.end local v17 # "presentationTimestampUs":J
.end local v19 # "bufferSize":I
.end local v20 # "presentationTimestampMs":J
.end local v22 # "builder":Lorg/webrtc/ali/EncodedImage$Builder;
:catch_fb
move-exception v0
move-object/from16 v15, p2
.line 224
.restart local v0 # "e":Ljava/lang/IllegalStateException;
const-string v5, "getInputBuffers failed"
invoke-static {v2, v5, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 225
sget-object v2, Lorg/webrtc/ali/VideoCodecStatus;->FALLBACK_SOFTWARE:Lorg/webrtc/ali/VideoCodecStatus;
return-object v2
.line 203
.end local v0 # "e":Ljava/lang/IllegalStateException;
.end local v12 # "index":I
:catch_106
move-exception v0
move-object/from16 v15, p2
.line 204
.restart local v0 # "e":Ljava/lang/IllegalStateException;
const-string v5, "dequeueInputBuffer failed"
invoke-static {v2, v5, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 205
sget-object v2, Lorg/webrtc/ali/VideoCodecStatus;->FALLBACK_SOFTWARE:Lorg/webrtc/ali/VideoCodecStatus;
return-object v2
.end method
.method public getImplementationName()Ljava/lang/String;
.registers 3
.line 290
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "HardwareVideoEncoder: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codecName:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getScalingSettings()Lorg/webrtc/ali/VideoEncoder$ScalingSettings;
.registers 2
.line 285
const/4 v0, 0x0
return-object v0
.end method
.method public initEncode(Lorg/webrtc/ali/VideoEncoder$Settings;Lorg/webrtc/ali/VideoEncoder$Callback;)Lorg/webrtc/ali/VideoCodecStatus;
.registers 9
.param p1, "settings" # Lorg/webrtc/ali/VideoEncoder$Settings;
.param p2, "callback" # Lorg/webrtc/ali/VideoEncoder$Callback;
.line 113
iget v1, p1, Lorg/webrtc/ali/VideoEncoder$Settings;->width:I
iget v2, p1, Lorg/webrtc/ali/VideoEncoder$Settings;->height:I
iget v3, p1, Lorg/webrtc/ali/VideoEncoder$Settings;->startBitrate:I
iget v4, p1, Lorg/webrtc/ali/VideoEncoder$Settings;->maxFramerate:I
move-object v0, p0
move-object v5, p2
invoke-direct/range {v0 .. v5}, Lorg/webrtc/ali/HardwareVideoEncoder;->initEncodeInternal(IIIILorg/webrtc/ali/VideoEncoder$Callback;)Lorg/webrtc/ali/VideoCodecStatus;
move-result-object v0
return-object v0
.end method
.method public release()Lorg/webrtc/ali/VideoCodecStatus;
.registers 5
.line 165
const/4 v0, 0x0
const/4 v1, 0x0
:try_start_2
iput-boolean v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->running:Z
.line 166
iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputThread:Ljava/lang/Thread;
const-wide/16 v2, 0x1388
invoke-static {v0, v2, v3}, Lorg/webrtc/ali/ThreadUtils;->joinUninterruptibly(Ljava/lang/Thread;J)Z
move-result v0
:try_end_c
.catchall {:try_start_2 .. :try_end_c} :catchall_45
const-string v2, "HardwareVideoEncoder"
if-nez v0, :cond_21
.line 167
:try_start_10
const-string v0, "Media encoder release timeout"
invoke-static {v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 168
sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->TIMEOUT:Lorg/webrtc/ali/VideoCodecStatus;
:try_end_17
.catchall {:try_start_10 .. :try_end_17} :catchall_45
.line 176
iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
.line 177
iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputThread:Ljava/lang/Thread;
.line 178
iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;
invoke-interface {v1}, Ljava/util/Deque;->clear()V
.line 168
return-object v0
.line 170
:cond_21
:try_start_21
iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->shutdownException:Ljava/lang/Exception;
if-eqz v0, :cond_38
.line 172
const-string v0, "Media encoder release exception"
iget-object v3, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->shutdownException:Ljava/lang/Exception;
invoke-static {v2, v0, v3}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 173
sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->ERROR:Lorg/webrtc/ali/VideoCodecStatus;
:try_end_2e
.catchall {:try_start_21 .. :try_end_2e} :catchall_45
.line 176
iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
.line 177
iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputThread:Ljava/lang/Thread;
.line 178
iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;
invoke-interface {v1}, Ljava/util/Deque;->clear()V
.line 173
return-object v0
.line 176
:cond_38
iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
.line 177
iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputThread:Ljava/lang/Thread;
.line 178
iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;
invoke-interface {v0}, Ljava/util/Deque;->clear()V
.line 179
nop
.line 180
sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;
return-object v0
.line 176
:catchall_45
move-exception v0
iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->codec:Landroid/media/MediaCodec;
.line 177
iput-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputThread:Ljava/lang/Thread;
.line 178
iget-object v1, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->outputBuilders:Ljava/util/Deque;
invoke-interface {v1}, Ljava/util/Deque;->clear()V
.line 179
throw v0
.end method
.method public setChannelParameters(SJ)Lorg/webrtc/ali/VideoCodecStatus;
.registers 5
.param p1, "packetLoss" # S
.param p2, "roundTripTimeMs" # J
.line 270
sget-object v0, Lorg/webrtc/ali/VideoCodecStatus;->OK:Lorg/webrtc/ali/VideoCodecStatus;
return-object v0
.end method
.method public setRateAllocation(Lorg/webrtc/ali/VideoEncoder$BitrateAllocation;I)Lorg/webrtc/ali/VideoCodecStatus;
.registers 5
.param p1, "bitrateAllocation" # Lorg/webrtc/ali/VideoEncoder$BitrateAllocation;
.param p2, "framerate" # I
.line 275
const/16 v0, 0x1e
if-le p2, v0, :cond_6
.line 276
const/16 p2, 0x1e
.line 278
:cond_6
iget-object v0, p0, Lorg/webrtc/ali/HardwareVideoEncoder;->bitrateAdjuster:Lorg/webrtc/ali/BitrateAdjuster;
invoke-virtual {p1}, Lorg/webrtc/ali/VideoEncoder$BitrateAllocation;->getSum()I
move-result v1
invoke-interface {v0, v1, p2}, Lorg/webrtc/ali/BitrateAdjuster;->setTargets(II)V
.line 279
invoke-direct {p0}, Lorg/webrtc/ali/HardwareVideoEncoder;->updateBitrate()Lorg/webrtc/ali/VideoCodecStatus;
move-result-object v0
return-object v0
.end method