.class public Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; .super Lcom/mbridge/msdk/thrid/okio/Timeout; .source "SourceFile" # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lcom/mbridge/msdk/thrid/okio/AsyncTimeout$Watchdog; } .end annotation # static fields .field private static final IDLE_TIMEOUT_MILLIS:J .field private static final IDLE_TIMEOUT_NANOS:J .field private static final TIMEOUT_WRITE_SIZE:I = 0x10000 .field static head:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; .annotation build Landroidx/annotation/Nullable; .end annotation .end field # instance fields .field private inQueue:Z .field private next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; .annotation build Landroidx/annotation/Nullable; .end annotation .end field .field private timeoutAt:J # direct methods .method static constructor ()V .locals 3 .line 50 sget-object v0, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit; const-wide/16 v1, 0x3c invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J move-result-wide v0 sput-wide v0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->IDLE_TIMEOUT_MILLIS:J .line 51 sget-object v2, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit; invoke-virtual {v2, v0, v1}, Ljava/util/concurrent/TimeUnit;->toNanos(J)J move-result-wide v0 sput-wide v0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->IDLE_TIMEOUT_NANOS:J return-void .end method .method public constructor ()V .locals 0 .line 41 invoke-direct {p0}, Lcom/mbridge/msdk/thrid/okio/Timeout;->()V return-void .end method .method public static awaitTimeout()Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; .locals 9 .annotation build Landroidx/annotation/Nullable; .end annotation .annotation system Ldalvik/annotation/Throws; value = { Ljava/lang/InterruptedException; } .end annotation sget-object v0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->head:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; .line 342 iget-object v0, v0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; const-class v1, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; const/4 v2, 0x0 if-nez v0, :cond_1 .line 346 invoke-static {}, Ljava/lang/System;->nanoTime()J move-result-wide v3 sget-wide v5, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->IDLE_TIMEOUT_MILLIS:J .line 347 invoke-virtual {v1, v5, v6}, Ljava/lang/Object;->wait(J)V sget-object v0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->head:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; .line 348 iget-object v0, v0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; if-nez v0, :cond_0 invoke-static {}, Ljava/lang/System;->nanoTime()J move-result-wide v0 sub-long/2addr v0, v3 sget-wide v3, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->IDLE_TIMEOUT_NANOS:J cmp-long v0, v0, v3 if-ltz v0, :cond_0 sget-object v2, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->head:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; :cond_0 return-object v2 .line 353 :cond_1 invoke-static {}, Ljava/lang/System;->nanoTime()J move-result-wide v3 invoke-direct {v0, v3, v4}, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->remainingNanos(J)J move-result-wide v3 const-wide/16 v5, 0x0 cmp-long v5, v3, v5 if-lez v5, :cond_2 const-wide/32 v5, 0xf4240 .line 359 div-long v7, v3, v5 mul-long/2addr v5, v7 sub-long/2addr v3, v5 long-to-int v0, v3 .line 361 invoke-virtual {v1, v7, v8, v0}, Ljava/lang/Object;->wait(JI)V return-object v2 :cond_2 sget-object v1, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->head:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; .line 366 iget-object v3, v0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; iput-object v3, v1, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; .line 367 iput-object v2, v0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; return-object v0 .end method .method private static declared-synchronized cancelScheduledTimeout(Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;)Z .locals 3 const-class v0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; monitor-enter v0 :try_start_0 sget-object v1, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->head:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; :goto_0 if-eqz v1, :cond_1 .line 129 iget-object v2, v1, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; if-ne v2, p0, :cond_0 .line 130 iget-object v2, p0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; iput-object v2, v1, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; const/4 v1, 0x0 .line 131 iput-object v1, p0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 132 monitor-exit v0 const/4 p0, 0x0 return p0 :catchall_0 move-exception p0 goto :goto_1 :cond_0 move-object v1, v2 goto :goto_0 .line 137 :cond_1 monitor-exit v0 const/4 p0, 0x1 return p0 :goto_1 monitor-exit v0 throw p0 .end method .method private remainingNanos(J)J .locals 2 iget-wide v0, p0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->timeoutAt:J sub-long/2addr v0, p1 return-wide v0 .end method .method private static declared-synchronized scheduleTimeout(Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;JZ)V .locals 5 const-class v0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; monitor-enter v0 :try_start_0 sget-object v1, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->head:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; if-nez v1, :cond_0 .line 87 new-instance v1, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; invoke-direct {v1}, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->()V sput-object v1, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->head:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; .line 88 new-instance v1, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout$Watchdog; invoke-direct {v1}, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout$Watchdog;->()V invoke-virtual {v1}, Ljava/lang/Thread;->start()V goto :goto_0 :catchall_0 move-exception p0 goto :goto_4 .line 91 :cond_0 :goto_0 invoke-static {}, Ljava/lang/System;->nanoTime()J move-result-wide v1 const-wide/16 v3, 0x0 cmp-long v3, p1, v3 if-eqz v3, :cond_1 if-eqz p3, :cond_1 .line 95 invoke-virtual {p0}, Lcom/mbridge/msdk/thrid/okio/Timeout;->deadlineNanoTime()J move-result-wide v3 sub-long/2addr v3, v1 invoke-static {p1, p2, v3, v4}, Ljava/lang/Math;->min(JJ)J move-result-wide p1 add-long/2addr p1, v1 iput-wide p1, p0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->timeoutAt:J goto :goto_1 :cond_1 if-eqz v3, :cond_2 add-long/2addr p1, v1 .line 97 iput-wide p1, p0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->timeoutAt:J goto :goto_1 :cond_2 if-eqz p3, :cond_6 .line 99 invoke-virtual {p0}, Lcom/mbridge/msdk/thrid/okio/Timeout;->deadlineNanoTime()J move-result-wide p1 iput-wide p1, p0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->timeoutAt:J .line 105 :goto_1 invoke-direct {p0, v1, v2}, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->remainingNanos(J)J move-result-wide p1 sget-object p3, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->head:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; .line 107 :goto_2 iget-object v3, p3, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; if-eqz v3, :cond_4 invoke-direct {v3, v1, v2}, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->remainingNanos(J)J move-result-wide v3 cmp-long v3, p1, v3 if-gez v3, :cond_3 goto :goto_3 .line 106 :cond_3 iget-object p3, p3, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; goto :goto_2 .line 108 :cond_4 :goto_3 iget-object p1, p3, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; iput-object p1, p0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; .line 109 iput-object p0, p3, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->next:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; sget-object p0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->head:Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; if-ne p3, p0, :cond_5 const-class p0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout; .line 111 invoke-virtual {p0}, Ljava/lang/Object;->notify()V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 116 :cond_5 monitor-exit v0 return-void .line 101 :cond_6 :try_start_1 new-instance p0, Ljava/lang/AssertionError; invoke-direct {p0}, Ljava/lang/AssertionError;->()V throw p0 :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 :goto_4 monitor-exit v0 throw p0 .end method # virtual methods .method public final enter()V .locals 5 iget-boolean v0, p0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->inQueue:Z if-nez v0, :cond_1 .line 74 invoke-virtual {p0}, Lcom/mbridge/msdk/thrid/okio/Timeout;->timeoutNanos()J move-result-wide v0 .line 75 invoke-virtual {p0}, Lcom/mbridge/msdk/thrid/okio/Timeout;->hasDeadline()Z move-result v2 const-wide/16 v3, 0x0 cmp-long v3, v0, v3 if-nez v3, :cond_0 if-nez v2, :cond_0 return-void :cond_0 const/4 v3, 0x1 iput-boolean v3, p0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->inQueue:Z .line 80 invoke-static {p0, v0, v1, v2}, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->scheduleTimeout(Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;JZ)V return-void .line 73 :cond_1 new-instance v0, Ljava/lang/IllegalStateException; const-string v1, "Unbalanced enter/exit" invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;)V throw v0 .end method .method public final exit(Ljava/io/IOException;)Ljava/io/IOException; .locals 1 .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation .line 284 invoke-virtual {p0}, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->exit()Z move-result v0 if-nez v0, :cond_0 return-object p1 .line 285 :cond_0 invoke-virtual {p0, p1}, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->newTimeoutException(Ljava/io/IOException;)Ljava/io/IOException; move-result-object p1 return-object p1 .end method .method public final exit(Z)V .locals 1 .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation .line 274 invoke-virtual {p0}, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->exit()Z move-result v0 if-eqz v0, :cond_1 if-nez p1, :cond_0 goto :goto_0 :cond_0 const/4 p1, 0x0 .line 275 invoke-virtual {p0, p1}, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->newTimeoutException(Ljava/io/IOException;)Ljava/io/IOException; move-result-object p1 throw p1 :cond_1 :goto_0 return-void .end method .method public final exit()Z .locals 2 iget-boolean v0, p0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->inQueue:Z const/4 v1, 0x0 if-nez v0, :cond_0 return v1 :cond_0 iput-boolean v1, p0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->inQueue:Z .line 122 invoke-static {p0}, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;->cancelScheduledTimeout(Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;)Z move-result v0 return v0 .end method .method public newTimeoutException(Ljava/io/IOException;)Ljava/io/IOException; .locals 2 .param p1 # Ljava/io/IOException; .annotation build Landroidx/annotation/Nullable; .end annotation .end param .line 294 new-instance v0, Ljava/io/InterruptedIOException; const-string v1, "timeout" invoke-direct {v0, v1}, Ljava/io/InterruptedIOException;->(Ljava/lang/String;)V if-eqz p1, :cond_0 .line 296 invoke-virtual {v0, p1}, Ljava/lang/Throwable;->initCause(Ljava/lang/Throwable;)Ljava/lang/Throwable; :cond_0 return-object v0 .end method .method public final sink(Lcom/mbridge/msdk/thrid/okio/Sink;)Lcom/mbridge/msdk/thrid/okio/Sink; .locals 1 .line 160 new-instance v0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout$1; invoke-direct {v0, p0, p1}, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout$1;->(Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;Lcom/mbridge/msdk/thrid/okio/Sink;)V return-object v0 .end method .method public final source(Lcom/mbridge/msdk/thrid/okio/Source;)Lcom/mbridge/msdk/thrid/okio/Source; .locals 1 .line 232 new-instance v0, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout$2; invoke-direct {v0, p0, p1}, Lcom/mbridge/msdk/thrid/okio/AsyncTimeout$2;->(Lcom/mbridge/msdk/thrid/okio/AsyncTimeout;Lcom/mbridge/msdk/thrid/okio/Source;)V return-object v0 .end method .method public timedOut()V .locals 0 return-void .end method