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