MMCStatus.smali
.class public Lcom/mmc/player/utils/MMCStatus;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field private static final CPU_TEMP_FILE_1:Ljava/lang/String; = "/sys/class/thermal/thermal_zone0/temp"
.field private static final CPU_TEMP_FILE_2:Ljava/lang/String; = "/sys/devices/virtual/thermal/thermal_zone0/temp"
.field private static final TAG:Ljava/lang/String; = "MMCStatus"
.field public static final TEMP_NOT_SET:D = -1.0
.field private static final UNREADABLE_FILE:Ljava/util/HashSet;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/HashSet<",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
.field private static volatile activityManager:Landroid/app/ActivityManager;
.field private static final handlerLock:Ljava/lang/Object;
.field private static volatile mAppMemoryUsage:D
.field private static volatile mAppTotalRxBytes:J
.field private static volatile mCpuTemperature:D
.field private static volatile mCpuUsage:F
.field private static volatile mDeviceTotalRxBytes:J
.field private static mJiffyEnlarge:I
.field private static mJiffyMillis:J
.field private static volatile mMachineMemoryUsage:D
.field private static mStatusHandler:Landroid/os/Handler;
.field private static volatile mStatusThread:Landroid/os/HandlerThread;
.field private static totalAppTime:J
.field private static totalCpuTime:J
.field private static totalSystemCpuTime:J
.field private static totalSystemTempCpuTime:J
.field private static final updateRunnable:Ljava/lang/Runnable;
# direct methods
.method public static constructor <clinit>()V
.registers 4
.line 1
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
sput-object v0, Lcom/mmc/player/utils/MMCStatus;->handlerLock:Ljava/lang/Object;
.line 2
new-instance v0, Lcom/mmc/player/utils/MMCStatus$1;
invoke-direct {v0}, Lcom/mmc/player/utils/MMCStatus$1;-><init>()V
sput-object v0, Lcom/mmc/player/utils/MMCStatus;->updateRunnable:Ljava/lang/Runnable;
.line 3
new-instance v0, Ljava/util/HashSet;
invoke-direct {v0}, Ljava/util/HashSet;-><init>()V
sput-object v0, Lcom/mmc/player/utils/MMCStatus;->UNREADABLE_FILE:Ljava/util/HashSet;
const-wide/16 v0, 0x0
.line 4
sput-wide v0, Lcom/mmc/player/utils/MMCStatus;->totalCpuTime:J
.line 5
sput-wide v0, Lcom/mmc/player/utils/MMCStatus;->totalAppTime:J
.line 6
sput-wide v0, Lcom/mmc/player/utils/MMCStatus;->totalSystemCpuTime:J
.line 7
sput-wide v0, Lcom/mmc/player/utils/MMCStatus;->totalSystemTempCpuTime:J
.line 8
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x1a
if-le v0, v1, :cond_3b
.line 9
sget v0, Landroid/system/OsConstants;->_SC_CLK_TCK:I
invoke-static {v0}, Landroid/system/Os;->sysconf(I)J
move-result-wide v0
const-wide/16 v2, 0x3e8
.line 10
div-long/2addr v2, v0
sput-wide v2, Lcom/mmc/player/utils/MMCStatus;->mJiffyMillis:J
.line 11
invoke-static {}, Ljava/lang/Runtime;->getRuntime()Ljava/lang/Runtime;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Runtime;->availableProcessors()I
move-result v0
sput v0, Lcom/mmc/player/utils/MMCStatus;->mJiffyEnlarge:I
goto :goto_42
:cond_3b
const/4 v0, 0x1
.line 12
sput v0, Lcom/mmc/player/utils/MMCStatus;->mJiffyEnlarge:I
const-wide/16 v0, 0x64
.line 13
sput-wide v0, Lcom/mmc/player/utils/MMCStatus;->mJiffyMillis:J
:goto_42
return-void
.end method
.method public constructor <init>()V
.registers 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static INVOKEVIRTUAL_com_mmc_player_utils_MMCStatus_com_shopee_app_asm_fix_androidx_ThreadFixer_start(Landroid/os/HandlerThread;)V
.registers 3
.line 1
:try_start_0
invoke-static {}, Lcom/shopee/app/asm/fix/androidx/b;->b()Z
move-result v0
if-eqz v0, :cond_12
.line 2
invoke-static {p0}, Lcom/shopee/app/asm/fix/androidx/b;->a(Ljava/lang/Thread;)V
:try_end_9
.catchall {:try_start_0 .. :try_end_9} :catchall_a
goto :goto_12
:catchall_a
move-exception v0
.line 3
invoke-static {}, Lcom/shopee/app/apm/c;->d()Lcom/shopee/app/apm/nonfatal/a;
move-result-object v1
invoke-virtual {v1, v0}, Lcom/shopee/app/apm/nonfatal/a;->c(Ljava/lang/Throwable;)V
.line 4
:cond_12
:goto_12
invoke-virtual {p0}, Ljava/lang/Thread;->start()V
return-void
.end method
.method public static INVOKEVIRTUAL_com_mmc_player_utils_MMCStatus_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/IOException;)V
.registers 1
return-void
.end method
.method public static INVOKEVIRTUAL_com_mmc_player_utils_MMCStatus_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/lang/Exception;)V
.registers 1
return-void
.end method
.method public static synthetic access$000()Landroid/os/HandlerThread;
.registers 1
sget-object v0, Lcom/mmc/player/utils/MMCStatus;->mStatusThread:Landroid/os/HandlerThread;
return-object v0
.end method
.method public static synthetic access$100()Landroid/os/Handler;
.registers 1
sget-object v0, Lcom/mmc/player/utils/MMCStatus;->mStatusHandler:Landroid/os/Handler;
return-object v0
.end method
.method public static synthetic access$200()Ljava/lang/Runnable;
.registers 1
sget-object v0, Lcom/mmc/player/utils/MMCStatus;->updateRunnable:Ljava/lang/Runnable;
return-object v0
.end method
.method public static synthetic access$300()V
.registers 0
invoke-static {}, Lcom/mmc/player/utils/MMCStatus;->updateAllStatics()V
return-void
.end method
.method public static deinit()V
.registers 4
.line 1
sget-object v0, Lcom/mmc/player/utils/MMCStatus;->handlerLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
sget-object v1, Lcom/mmc/player/utils/MMCStatus;->mStatusHandler:Landroid/os/Handler;
if-eqz v1, :cond_24
sget-object v1, Lcom/mmc/player/utils/MMCStatus;->mStatusThread:Landroid/os/HandlerThread;
if-eqz v1, :cond_24
.line 3
sget-object v1, Lcom/mmc/player/utils/MMCStatus;->mStatusHandler:Landroid/os/Handler;
const/4 v2, 0x0
invoke-virtual {v1, v2}, Landroid/os/Handler;->removeCallbacksAndMessages(Ljava/lang/Object;)V
.line 4
sget v1, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v3, 0x17
if-lt v1, v3, :cond_1d
.line 5
sget-object v1, Lcom/mmc/player/utils/MMCStatus;->mStatusThread:Landroid/os/HandlerThread;
invoke-virtual {v1}, Landroid/os/HandlerThread;->quitSafely()Z
goto :goto_22
.line 6
:cond_1d
sget-object v1, Lcom/mmc/player/utils/MMCStatus;->mStatusThread:Landroid/os/HandlerThread;
invoke-virtual {v1}, Landroid/os/HandlerThread;->quit()Z
.line 7
:goto_22
sput-object v2, Lcom/mmc/player/utils/MMCStatus;->mStatusThread:Landroid/os/HandlerThread;
.line 8
:cond_24
monitor-exit v0
return-void
:catchall_26
move-exception v1
monitor-exit v0
:try_end_28
.catchall {:try_start_3 .. :try_end_28} :catchall_26
throw v1
.end method
.method public static getAppMemoryUsage()D
.registers 2
sget-wide v0, Lcom/mmc/player/utils/MMCStatus;->mAppMemoryUsage:D
return-wide v0
.end method
.method public static getAppTotalRxBytes()J
.registers 2
sget-wide v0, Lcom/mmc/player/utils/MMCStatus;->mAppTotalRxBytes:J
return-wide v0
.end method
.method public static getCpuTemperature()D
.registers 2
sget-wide v0, Lcom/mmc/player/utils/MMCStatus;->mCpuTemperature:D
return-wide v0
.end method
.method public static getCpuUsage()F
.registers 1
sget v0, Lcom/mmc/player/utils/MMCStatus;->mCpuUsage:F
return v0
.end method
.method public static getDeviceTotalRxBytes()J
.registers 2
sget-wide v0, Lcom/mmc/player/utils/MMCStatus;->mDeviceTotalRxBytes:J
return-wide v0
.end method
.method public static getMachineMemoryUsage()D
.registers 2
sget-wide v0, Lcom/mmc/player/utils/MMCStatus;->mMachineMemoryUsage:D
return-wide v0
.end method
.method public static init(Landroid/content/Context;)V
.registers 2
.line 1
invoke-virtual {p0}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object p0
const-string v0, "activity"
.line 2
invoke-virtual {p0, v0}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;
move-result-object p0
check-cast p0, Landroid/app/ActivityManager;
sput-object p0, Lcom/mmc/player/utils/MMCStatus;->activityManager:Landroid/app/ActivityManager;
.line 3
invoke-static {}, Lcom/mmc/player/utils/MMCStatus;->initHandler()V
return-void
.end method
.method private static initHandler()V
.registers 5
.line 1
sget-object v0, Lcom/mmc/player/utils/MMCStatus;->handlerLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
sget-object v1, Lcom/mmc/player/utils/MMCStatus;->mStatusThread:Landroid/os/HandlerThread;
if-nez v1, :cond_15
.line 3
new-instance v1, Landroid/os/HandlerThread;
const-string v2, "MMCStatus"
invoke-direct {v1, v2}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;)V
sput-object v1, Lcom/mmc/player/utils/MMCStatus;->mStatusThread:Landroid/os/HandlerThread;
.line 4
sget-object v1, Lcom/mmc/player/utils/MMCStatus;->mStatusThread:Landroid/os/HandlerThread;
invoke-static {v1}, Lcom/mmc/player/utils/MMCStatus;->INVOKEVIRTUAL_com_mmc_player_utils_MMCStatus_com_shopee_app_asm_fix_androidx_ThreadFixer_start(Landroid/os/HandlerThread;)V
.line 5
:cond_15
sget-object v1, Lcom/mmc/player/utils/MMCStatus;->mStatusThread:Landroid/os/HandlerThread;
if-eqz v1, :cond_4e
sget-object v1, Lcom/mmc/player/utils/MMCStatus;->mStatusHandler:Landroid/os/Handler;
if-nez v1, :cond_4e
.line 6
new-instance v1, Landroid/os/Handler;
sget-object v2, Lcom/mmc/player/utils/MMCStatus;->mStatusThread:Landroid/os/HandlerThread;
invoke-virtual {v2}, Landroid/os/HandlerThread;->getLooper()Landroid/os/Looper;
move-result-object v2
invoke-direct {v1, v2}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V
sput-object v1, Lcom/mmc/player/utils/MMCStatus;->mStatusHandler:Landroid/os/Handler;
.line 7
sget-object v2, Lcom/mmc/player/utils/MMCStatus;->updateRunnable:Ljava/lang/Runnable;
invoke-virtual {v1, v2}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
:try_end_2f
.catchall {:try_start_3 .. :try_end_2f} :catchall_30
goto :goto_4e
:catchall_30
move-exception v1
:try_start_31
const-string v2, "MMCStatus"
.line 8
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "initHandler error "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/Throwable;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
const/4 v3, 0x0
new-array v3, v3, [Ljava/lang/Object;
.line 9
invoke-static {v2, v1, v3}, Lcom/shopee/shopeexlog/config/b;->B(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
.line 10
:cond_4e
:goto_4e
monitor-exit v0
return-void
:catchall_50
move-exception v1
monitor-exit v0
:try_end_52
.catchall {:try_start_31 .. :try_end_52} :catchall_50
throw v1
.end method
.method public static declared-synchronized initThread()V
.registers 4
const-class v0, Lcom/mmc/player/utils/MMCStatus;
monitor-enter v0
:try_start_3
const-string v1, "MMCStatus"
const-string v2, "initThread"
const/4 v3, 0x0
new-array v3, v3, [Ljava/lang/Object;
.line 1
invoke-static {v1, v2, v3}, Lcom/shopee/shopeexlog/config/b;->B(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
.line 2
sget-object v1, Lcom/mmc/player/utils/MMCStatus;->handlerLock:Ljava/lang/Object;
monitor-enter v1
:try_end_10
.catchall {:try_start_3 .. :try_end_10} :catchall_28
.line 3
:try_start_10
sget-object v2, Lcom/mmc/player/utils/MMCStatus;->mStatusThread:Landroid/os/HandlerThread;
if-nez v2, :cond_22
.line 4
new-instance v2, Landroid/os/HandlerThread;
const-string v3, "MMCStatus"
invoke-direct {v2, v3}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;)V
sput-object v2, Lcom/mmc/player/utils/MMCStatus;->mStatusThread:Landroid/os/HandlerThread;
.line 5
sget-object v2, Lcom/mmc/player/utils/MMCStatus;->mStatusThread:Landroid/os/HandlerThread;
invoke-static {v2}, Lcom/mmc/player/utils/MMCStatus;->INVOKEVIRTUAL_com_mmc_player_utils_MMCStatus_com_shopee_app_asm_fix_androidx_ThreadFixer_start(Landroid/os/HandlerThread;)V
.line 6
:cond_22
monitor-exit v1
:try_end_23
.catchall {:try_start_10 .. :try_end_23} :catchall_25
.line 7
monitor-exit v0
return-void
:catchall_25
move-exception v2
.line 8
:try_start_26
monitor-exit v1
:try_end_27
.catchall {:try_start_26 .. :try_end_27} :catchall_25
:try_start_27
throw v2
:try_end_28
.catchall {:try_start_27 .. :try_end_28} :catchall_28
:catchall_28
move-exception v1
monitor-exit v0
throw v1
.end method
.method private static readAppProc()J
.registers 7
.line 1
invoke-static {}, Landroid/os/Process;->myPid()I
move-result v0
.line 2
:try_start_4
new-instance v1, Ljava/io/BufferedReader;
new-instance v2, Ljava/io/InputStreamReader;
new-instance v3, Ljava/io/FileInputStream;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "/proc/"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v0, "/stat"
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v3, v0}, Ljava/io/FileInputStream;-><init>(Ljava/lang/String;)V
invoke-direct {v2, v3}, Ljava/io/InputStreamReader;-><init>(Ljava/io/InputStream;)V
const/16 v0, 0x3e8
invoke-direct {v1, v2, v0}, Ljava/io/BufferedReader;-><init>(Ljava/io/Reader;I)V
:try_end_2b
.catch Ljava/io/IOException; {:try_start_4 .. :try_end_2b} :catch_77
.line 3
:try_start_2b
invoke-virtual {v1}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object v0
const-string v2, "\\s+"
.line 4
invoke-virtual {v0, v2}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v0
if-eqz v0, :cond_69
.line 5
array-length v2, v0
const/16 v3, 0xd
if-le v2, v3, :cond_69
aget-object v2, v0, v3
invoke-static {v2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_69
.line 6
aget-object v2, v0, v3
invoke-static {v2}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v2
const/16 v4, 0xe
.line 7
aget-object v4, v0, v4
invoke-static {v4}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v4
const/16 v6, 0xf
.line 8
aget-object v6, v0, v6
invoke-static {v6}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
const/16 v6, 0x10
.line 9
aget-object v0, v0, v6
invoke-static {v0}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
add-long/2addr v2, v4
.line 10
sget-wide v4, Lcom/mmc/player/utils/MMCStatus;->mJiffyMillis:J
:try_end_63
.catchall {:try_start_2b .. :try_end_63} :catchall_6d
mul-long v2, v2, v4
.line 11
:try_start_65
invoke-virtual {v1}, Ljava/io/BufferedReader;->close()V
return-wide v2
:cond_69
invoke-virtual {v1}, Ljava/io/BufferedReader;->close()V
:try_end_6c
.catch Ljava/io/IOException; {:try_start_65 .. :try_end_6c} :catch_77
goto :goto_7b
:catchall_6d
move-exception v0
.line 12
:try_start_6e
invoke-virtual {v1}, Ljava/io/BufferedReader;->close()V
:try_end_71
.catchall {:try_start_6e .. :try_end_71} :catchall_72
goto :goto_76
:catchall_72
move-exception v1
:try_start_73
invoke-virtual {v0, v1}, Ljava/lang/Throwable;->addSuppressed(Ljava/lang/Throwable;)V
:goto_76
throw v0
:try_end_77
.catch Ljava/io/IOException; {:try_start_73 .. :try_end_77} :catch_77
:catch_77
move-exception v0
.line 13
invoke-static {v0}, Lcom/mmc/player/utils/MMCStatus;->INVOKEVIRTUAL_com_mmc_player_utils_MMCStatus_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/IOException;)V
:goto_7b
const-wide/16 v0, 0x0
return-wide v0
.end method
.method private static readCpus()J
.registers 16
.line 1
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x1a
if-ge v0, v1, :cond_7b
.line 2
:try_start_6
new-instance v0, Ljava/io/BufferedReader;
new-instance v1, Ljava/io/InputStreamReader;
new-instance v2, Ljava/io/FileInputStream;
const-string v3, "/proc/stat"
invoke-direct {v2, v3}, Ljava/io/FileInputStream;-><init>(Ljava/lang/String;)V
invoke-direct {v1, v2}, Ljava/io/InputStreamReader;-><init>(Ljava/io/InputStream;)V
const/16 v2, 0x3e8
invoke-direct {v0, v1, v2}, Ljava/io/BufferedReader;-><init>(Ljava/io/Reader;I)V
:try_end_19
.catch Ljava/lang/Exception; {:try_start_6 .. :try_end_19} :catch_77
.line 3
:try_start_19
invoke-virtual {v0}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object v1
const-string v2, "\\s+"
.line 4
invoke-virtual {v1, v2}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v1
if-eqz v1, :cond_69
.line 5
array-length v2, v1
const/16 v3, 0x8
if-lt v2, v3, :cond_69
const/4 v2, 0x1
.line 6
aget-object v2, v1, v2
invoke-static {v2}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v2
const/4 v4, 0x2
.line 7
aget-object v4, v1, v4
invoke-static {v4}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v4
const/4 v6, 0x3
.line 8
aget-object v6, v1, v6
invoke-static {v6}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v6
const/4 v8, 0x4
.line 9
aget-object v8, v1, v8
invoke-static {v8}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v8
const/4 v10, 0x5
.line 10
aget-object v10, v1, v10
invoke-static {v10}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
const/4 v10, 0x6
.line 11
aget-object v10, v1, v10
invoke-static {v10}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
const/4 v10, 0x7
.line 12
aget-object v1, v1, v10
invoke-static {v1}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v10
.line 13
sget-wide v12, Lcom/mmc/player/utils/MMCStatus;->mJiffyMillis:J
mul-long v14, v6, v12
sput-wide v14, Lcom/mmc/player/utils/MMCStatus;->totalSystemTempCpuTime:J
:try_end_5f
.catchall {:try_start_19 .. :try_end_5f} :catchall_6d
add-long/2addr v2, v4
add-long/2addr v2, v6
add-long/2addr v2, v8
add-long/2addr v2, v10
mul-long v2, v2, v12
.line 14
:try_start_65
invoke-virtual {v0}, Ljava/io/BufferedReader;->close()V
return-wide v2
:cond_69
invoke-virtual {v0}, Ljava/io/BufferedReader;->close()V
:try_end_6c
.catch Ljava/lang/Exception; {:try_start_65 .. :try_end_6c} :catch_77
goto :goto_7b
:catchall_6d
move-exception v1
.line 15
:try_start_6e
invoke-virtual {v0}, Ljava/io/BufferedReader;->close()V
:try_end_71
.catchall {:try_start_6e .. :try_end_71} :catchall_72
goto :goto_76
:catchall_72
move-exception v0
:try_start_73
invoke-virtual {v1, v0}, Ljava/lang/Throwable;->addSuppressed(Ljava/lang/Throwable;)V
:goto_76
throw v1
:try_end_77
.catch Ljava/lang/Exception; {:try_start_73 .. :try_end_77} :catch_77
:catch_77
move-exception v0
.line 16
invoke-static {v0}, Lcom/mmc/player/utils/MMCStatus;->INVOKEVIRTUAL_com_mmc_player_utils_MMCStatus_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/lang/Exception;)V
.line 17
:cond_7b
:goto_7b
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
return-wide v0
.end method
.method private static readOneLine(Ljava/lang/String;)Ljava/lang/String;
.registers 7
.line 1
sget-object v0, Lcom/mmc/player/utils/MMCStatus;->UNREADABLE_FILE:Ljava/util/HashSet;
invoke-virtual {v0, p0}, Ljava/util/HashSet;->contains(Ljava/lang/Object;)Z
move-result v0
const-string v1, ""
if-eqz v0, :cond_b
return-object v1
:cond_b
const/4 v0, 0x0
.line 2
:try_start_c
new-instance v2, Ljava/io/BufferedReader;
new-instance v3, Ljava/io/InputStreamReader;
new-instance v4, Ljava/io/FileInputStream;
invoke-direct {v4, p0}, Ljava/io/FileInputStream;-><init>(Ljava/lang/String;)V
invoke-direct {v3, v4}, Ljava/io/InputStreamReader;-><init>(Ljava/io/InputStream;)V
const/16 v4, 0x3e8
invoke-direct {v2, v3, v4}, Ljava/io/BufferedReader;-><init>(Ljava/io/Reader;I)V
:try_end_1d
.catch Ljava/io/IOException; {:try_start_c .. :try_end_1d} :catch_2e
.catchall {:try_start_c .. :try_end_1d} :catchall_2c
.line 3
:try_start_1d
invoke-virtual {v2}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object v1
:try_end_21
.catch Ljava/io/IOException; {:try_start_1d .. :try_end_21} :catch_2a
.catchall {:try_start_1d .. :try_end_21} :catchall_69
.line 4
:try_start_21
invoke-virtual {v2}, Ljava/io/BufferedReader;->close()V
:try_end_24
.catch Ljava/io/IOException; {:try_start_21 .. :try_end_24} :catch_25
goto :goto_68
:catch_25
move-exception p0
.line 5
invoke-static {p0}, Lcom/mmc/player/utils/MMCStatus;->INVOKEVIRTUAL_com_mmc_player_utils_MMCStatus_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/IOException;)V
goto :goto_68
:catch_2a
move-exception v0
goto :goto_32
:catchall_2c
move-exception p0
goto :goto_6b
:catch_2e
move-exception v2
move-object v5, v2
move-object v2, v0
move-object v0, v5
.line 6
:goto_32
:try_start_32
instance-of v3, v0, Ljava/io/FileNotFoundException;
if-eqz v3, :cond_60
.line 7
sget-object v0, Lcom/mmc/player/utils/MMCStatus;->UNREADABLE_FILE:Ljava/util/HashSet;
invoke-virtual {v0, p0}, Ljava/util/HashSet;->contains(Ljava/lang/Object;)Z
move-result v3
if-nez v3, :cond_63
.line 8
invoke-virtual {v0, p0}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
const-string v0, "MMCStatus"
.line 9
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "java.io.FileNotFoundException: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p0, ": open failed: EACCES (Permission denied)"
invoke-virtual {v3, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
const/4 v3, 0x0
new-array v3, v3, [Ljava/lang/Object;
.line 10
invoke-static {v0, p0, v3}, Lcom/shopee/shopeexlog/config/b;->C(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_63
.line 11
:cond_60
invoke-static {v0}, Lcom/mmc/player/utils/MMCStatus;->INVOKEVIRTUAL_com_mmc_player_utils_MMCStatus_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/IOException;)V
:try_end_63
.catchall {:try_start_32 .. :try_end_63} :catchall_69
:cond_63
:goto_63
if-eqz v2, :cond_68
.line 12
:try_start_65
invoke-virtual {v2}, Ljava/io/BufferedReader;->close()V
:try_end_68
.catch Ljava/io/IOException; {:try_start_65 .. :try_end_68} :catch_25
:cond_68
:goto_68
return-object v1
:catchall_69
move-exception p0
move-object v0, v2
:goto_6b
if-eqz v0, :cond_75
:try_start_6d
invoke-virtual {v0}, Ljava/io/BufferedReader;->close()V
:try_end_70
.catch Ljava/io/IOException; {:try_start_6d .. :try_end_70} :catch_71
goto :goto_75
:catch_71
move-exception v0
.line 13
invoke-static {v0}, Lcom/mmc/player/utils/MMCStatus;->INVOKEVIRTUAL_com_mmc_player_utils_MMCStatus_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/IOException;)V
.line 14
:cond_75
:goto_75
throw p0
.end method
.method private static updateAllStatics()V
.registers 2
.line 1
invoke-static {}, Lcom/mmc/player/utils/MMCStatus;->updateAppMemoryUsage()D
move-result-wide v0
sput-wide v0, Lcom/mmc/player/utils/MMCStatus;->mAppMemoryUsage:D
.line 2
invoke-static {}, Lcom/mmc/player/utils/MMCStatus;->updateAppTotalRxBytes()J
move-result-wide v0
sput-wide v0, Lcom/mmc/player/utils/MMCStatus;->mAppTotalRxBytes:J
.line 3
invoke-static {}, Lcom/mmc/player/utils/MMCStatus;->updateDeviceTotalRxBytes()J
move-result-wide v0
sput-wide v0, Lcom/mmc/player/utils/MMCStatus;->mDeviceTotalRxBytes:J
.line 4
invoke-static {}, Lcom/mmc/player/utils/MMCStatus;->updateCpuTemperature()D
move-result-wide v0
sput-wide v0, Lcom/mmc/player/utils/MMCStatus;->mCpuTemperature:D
.line 5
invoke-static {}, Lcom/mmc/player/utils/MMCStatus;->updateCpuUsage()F
move-result v0
sput v0, Lcom/mmc/player/utils/MMCStatus;->mCpuUsage:F
.line 6
invoke-static {}, Lcom/mmc/player/utils/MMCStatus;->updateMachineMemoryUsage()D
move-result-wide v0
sput-wide v0, Lcom/mmc/player/utils/MMCStatus;->mMachineMemoryUsage:D
return-void
.end method
.method public static updateAppMemoryUsage()D
.registers 8
.line 1
sget-object v0, Lcom/mmc/player/utils/MMCStatus;->activityManager:Landroid/app/ActivityManager;
const-wide/16 v1, 0x0
if-nez v0, :cond_7
return-wide v1
.line 2
:cond_7
new-instance v0, Landroid/app/ActivityManager$MemoryInfo;
invoke-direct {v0}, Landroid/app/ActivityManager$MemoryInfo;-><init>()V
.line 3
sget-object v3, Lcom/mmc/player/utils/MMCStatus;->activityManager:Landroid/app/ActivityManager;
invoke-virtual {v3, v0}, Landroid/app/ActivityManager;->getMemoryInfo(Landroid/app/ActivityManager$MemoryInfo;)V
.line 4
iget-wide v3, v0, Landroid/app/ActivityManager$MemoryInfo;->totalMem:J
const-wide/16 v5, 0x3e8
div-long/2addr v3, v5
.line 5
sget-object v0, Lcom/mmc/player/utils/MMCStatus;->activityManager:Landroid/app/ActivityManager;
const/4 v5, 0x1
new-array v5, v5, [I
invoke-static {}, Landroid/os/Process;->myPid()I
move-result v6
const/4 v7, 0x0
aput v6, v5, v7
invoke-virtual {v0, v5}, Landroid/app/ActivityManager;->getProcessMemoryInfo([I)[Landroid/os/Debug$MemoryInfo;
move-result-object v0
.line 6
array-length v5, v0
if-lez v5, :cond_3d
.line 7
aget-object v0, v0, v7
invoke-virtual {v0}, Landroid/os/Debug$MemoryInfo;->getTotalPss()I
move-result v0
const-wide/16 v5, 0x0
cmp-long v7, v3, v5
if-lez v7, :cond_3d
const-wide/high16 v1, 0x4059000000000000L # 100.0
int-to-double v5, v0
mul-double v5, v5, v1
long-to-double v0, v3
div-double/2addr v5, v0
return-wide v5
:cond_3d
return-wide v1
.end method
.method public static updateAppTotalRxBytes()J
.registers 5
invoke-static {}, Landroid/os/Process;->myUid()I
move-result v0
invoke-static {v0}, Landroid/net/TrafficStats;->getUidRxBytes(I)J
move-result-wide v0
const-wide/16 v2, -0x1
cmp-long v4, v0, v2
if-nez v4, :cond_10
const-wide/16 v0, 0x0
:cond_10
return-wide v0
.end method
.method public static updateCpuTemperature()D
.registers 5
const-string v0, "/sys/class/thermal/thermal_zone0/temp"
.line 1
invoke-static {v0}, Lcom/mmc/player/utils/MMCStatus;->readOneLine(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 2
invoke-static {v0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v1
const-wide/high16 v2, -0x4010000000000000L # -1.0
if-eqz v1, :cond_1b
const-string v0, "/sys/devices/virtual/thermal/thermal_zone0/temp"
.line 3
invoke-static {v0}, Lcom/mmc/player/utils/MMCStatus;->readOneLine(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 4
invoke-static {v0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v1
if-eqz v1, :cond_1b
return-wide v2
.line 5
:cond_1b
:try_start_1b
invoke-static {v0}, Ljava/lang/Double;->parseDouble(Ljava/lang/String;)D
move-result-wide v2
:try_end_1f
.catch Ljava/lang/NumberFormatException; {:try_start_1b .. :try_end_1f} :catch_20
goto :goto_21
:catch_20
nop
:goto_21
const-wide v0, 0x408f400000000000L # 1000.0
div-double v0, v2, v0
double-to-int v4, v0
if-eqz v4, :cond_2c
move-wide v2, v0
:cond_2c
return-wide v2
.end method
.method public static updateCpuUsage()F
.registers 11
.line 1
invoke-static {}, Lcom/mmc/player/utils/MMCStatus;->readCpus()J
move-result-wide v0
.line 2
invoke-static {}, Lcom/mmc/player/utils/MMCStatus;->readAppProc()J
move-result-wide v2
const-wide/16 v4, 0x0
cmp-long v6, v2, v4
if-eqz v6, :cond_56
.line 3
sget-wide v6, Lcom/mmc/player/utils/MMCStatus;->totalCpuTime:J
cmp-long v8, v6, v4
if-eqz v8, :cond_56
.line 4
sget-wide v4, Lcom/mmc/player/utils/MMCStatus;->totalAppTime:J
sub-long v4, v2, v4
long-to-float v4, v4
sub-long v5, v0, v6
sget v7, Lcom/mmc/player/utils/MMCStatus;->mJiffyEnlarge:I
int-to-long v7, v7
mul-long v5, v5, v7
long-to-float v5, v5
div-float/2addr v4, v5
const/high16 v5, 0x42c80000 # 100.0f
mul-float v4, v4, v5
float-to-int v4, v4
const/4 v6, 0x0
.line 5
sget v7, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v8, 0x1a
if-ge v7, v8, :cond_42
.line 6
sget-wide v6, Lcom/mmc/player/utils/MMCStatus;->totalSystemTempCpuTime:J
sget-wide v8, Lcom/mmc/player/utils/MMCStatus;->totalSystemCpuTime:J
sub-long/2addr v6, v8
long-to-float v6, v6
sget-wide v7, Lcom/mmc/player/utils/MMCStatus;->totalCpuTime:J
sub-long v7, v0, v7
sget v9, Lcom/mmc/player/utils/MMCStatus;->mJiffyEnlarge:I
int-to-long v9, v9
mul-long v7, v7, v9
long-to-float v7, v7
div-float/2addr v6, v7
mul-float v6, v6, v5
float-to-int v6, v6
.line 7
:cond_42
sput-wide v2, Lcom/mmc/player/utils/MMCStatus;->totalAppTime:J
.line 8
sput-wide v0, Lcom/mmc/player/utils/MMCStatus;->totalCpuTime:J
.line 9
sget-wide v0, Lcom/mmc/player/utils/MMCStatus;->totalSystemTempCpuTime:J
sput-wide v0, Lcom/mmc/player/utils/MMCStatus;->totalSystemCpuTime:J
if-nez v6, :cond_4e
const/16 v6, 0x64
:cond_4e
const/high16 v0, 0x3f800000 # 1.0f
int-to-float v1, v4
mul-float v1, v1, v0
int-to-float v0, v6
div-float/2addr v1, v0
return v1
.line 10
:cond_56
sput-wide v2, Lcom/mmc/player/utils/MMCStatus;->totalAppTime:J
.line 11
sput-wide v0, Lcom/mmc/player/utils/MMCStatus;->totalCpuTime:J
const/4 v0, 0x0
return v0
.end method
.method public static updateDeviceTotalRxBytes()J
.registers 5
invoke-static {}, Landroid/net/TrafficStats;->getTotalRxBytes()J
move-result-wide v0
const-wide/16 v2, -0x1
cmp-long v4, v0, v2
if-nez v4, :cond_c
const-wide/16 v0, 0x0
:cond_c
return-wide v0
.end method
.method public static updateMachineMemoryUsage()D
.registers 9
.line 1
sget-object v0, Lcom/mmc/player/utils/MMCStatus;->activityManager:Landroid/app/ActivityManager;
const-wide/16 v1, 0x0
if-nez v0, :cond_7
return-wide v1
.line 2
:cond_7
new-instance v0, Landroid/app/ActivityManager$MemoryInfo;
invoke-direct {v0}, Landroid/app/ActivityManager$MemoryInfo;-><init>()V
.line 3
sget-object v3, Lcom/mmc/player/utils/MMCStatus;->activityManager:Landroid/app/ActivityManager;
invoke-virtual {v3, v0}, Landroid/app/ActivityManager;->getMemoryInfo(Landroid/app/ActivityManager$MemoryInfo;)V
.line 4
iget-wide v3, v0, Landroid/app/ActivityManager$MemoryInfo;->availMem:J
.line 5
iget-wide v5, v0, Landroid/app/ActivityManager$MemoryInfo;->totalMem:J
const-wide/16 v7, 0x0
cmp-long v0, v5, v7
if-lez v0, :cond_25
const-wide/high16 v0, 0x4059000000000000L # 100.0
sub-long v2, v5, v3
long-to-double v2, v2
mul-double v2, v2, v0
long-to-double v0, v5
div-double v1, v2, v0
:cond_25
return-wide v1
.end method