NativeHandler.smali
.class Lxcrash/NativeHandler;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field private static final DUMP_TRACE_FROM_DUMP_TRACE:I = 0x2
.field private static final DUMP_TRACE_FROM_SIGQUIT:I = 0x1
.field private static final instance:Lxcrash/NativeHandler;
# instance fields
.field private anrCallback:Lxcrash/f;
.field private anrCheckProcessState:Z
.field private anrEnable:Z
.field private anrTimeoutMs:J
.field private crashCallback:Lxcrash/f;
.field private crashRethrow:Z
.field private ctx:Landroid/content/Context;
.field private dumpTraceCallBack:Lxcrash/f;
.field private initNativeLibOk:Z
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 38
new-instance v0, Lxcrash/NativeHandler;
invoke-direct {v0}, Lxcrash/NativeHandler;-><init>()V
sput-object v0, Lxcrash/NativeHandler;->instance:Lxcrash/NativeHandler;
return-void
.end method
.method private constructor <init>()V
.registers 3
.line 53
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const-wide/16 v0, 0x3a98
.line 41
iput-wide v0, p0, Lxcrash/NativeHandler;->anrTimeoutMs:J
const/4 v0, 0x0
.line 51
iput-boolean v0, p0, Lxcrash/NativeHandler;->initNativeLibOk:Z
return-void
.end method
.method private static crashCallback(Ljava/lang/String;Ljava/lang/String;ZZLjava/lang/String;)V
.registers 6
.line 202
invoke-static {p0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-nez v0, :cond_32
if-eqz p2, :cond_17
.line 206
invoke-static {p3, p4}, Lxcrash/NativeHandler;->getStacktraceByThreadName(ZLjava/lang/String;)Ljava/lang/String;
move-result-object p2
.line 207
invoke-static {p2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result p3
if-nez p3, :cond_17
const-string p3, "java stacktrace"
.line 208
invoke-static {p0, p3, p2}, Lxcrash/j;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Z
.line 213
:cond_17
invoke-static {}, Lxcrash/l;->c()Ljava/lang/String;
move-result-object p2
const-string p3, "memory info"
invoke-static {p0, p3, p2}, Lxcrash/j;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Z
.line 216
invoke-static {}, Lxcrash/a;->a()Lxcrash/a;
move-result-object p2
.line 1109
iget-boolean p2, p2, Lxcrash/a;->b:Z
if-eqz p2, :cond_2b
const-string p2, "yes"
goto :goto_2d
:cond_2b
const-string p2, "no"
:goto_2d
const-string p3, "foreground"
.line 216
invoke-static {p0, p3, p2}, Lxcrash/j;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Z
.line 219
:cond_32
invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;
move-result-object p2
iget-object p2, p2, Lxcrash/NativeHandler;->crashCallback:Lxcrash/f;
if-eqz p2, :cond_4a
.line 222
:try_start_3a
invoke-interface {p2, p0, p1}, Lxcrash/f;->a(Ljava/lang/String;Ljava/lang/String;)V
:try_end_3d
.catch Ljava/lang/Exception; {:try_start_3a .. :try_end_3d} :catch_3e
goto :goto_4a
:catch_3e
move-exception p0
.line 224
invoke-static {}, Lxcrash/m;->d()Lxcrash/h;
move-result-object p1
const-string p2, "xcrash"
const-string p3, "NativeHandler native crash callback.onCrash failed"
invoke-interface {p1, p2, p3, p0}, Lxcrash/h;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 228
:cond_4a
:goto_4a
invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;
move-result-object p0
iget-boolean p0, p0, Lxcrash/NativeHandler;->crashRethrow:Z
if-nez p0, :cond_59
.line 229
invoke-static {}, Lxcrash/a;->a()Lxcrash/a;
move-result-object p0
invoke-virtual {p0}, Lxcrash/a;->b()V
:cond_59
return-void
.end method
.method static getInstance()Lxcrash/NativeHandler;
.registers 1
.line 57
sget-object v0, Lxcrash/NativeHandler;->instance:Lxcrash/NativeHandler;
return-object v0
.end method
.method private static getStacktraceByThreadName(ZLjava/lang/String;)Ljava/lang/String;
.registers 7
.line 182
:try_start_0
invoke-static {}, Ljava/lang/Thread;->getAllStackTraces()Ljava/util/Map;
move-result-object v0
invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
:cond_c
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_6e
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/util/Map$Entry;
.line 183
invoke-interface {v1}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/Thread;
if-eqz p0, :cond_2c
.line 184
invoke-virtual {v2}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v3
const-string v4, "main"
invoke-virtual {v3, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v3
if-nez v3, :cond_38
:cond_2c
if-nez p0, :cond_c
invoke-virtual {v2}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v2, p1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_c
.line 185
:cond_38
new-instance p0, Ljava/lang/StringBuilder;
invoke-direct {p0}, Ljava/lang/StringBuilder;-><init>()V
.line 186
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object p1
check-cast p1, [Ljava/lang/StackTraceElement;
array-length v0, p1
const/4 v1, 0x0
:goto_45
if-ge v1, v0, :cond_5d
aget-object v2, p1, v1
const-string v3, " at "
.line 187
invoke-virtual {p0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StackTraceElement;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {p0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, "\n"
invoke-virtual {p0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
add-int/lit8 v1, v1, 0x1
goto :goto_45
.line 189
:cond_5d
invoke-virtual {p0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
:try_end_61
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_61} :catch_62
return-object p0
:catch_62
move-exception p0
.line 193
invoke-static {}, Lxcrash/m;->d()Lxcrash/h;
move-result-object p1
const-string v0, "xcrash"
const-string v1, "NativeHandler getStacktraceByThreadName failed"
invoke-interface {p1, v0, v1, p0}, Lxcrash/h;->c(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
:cond_6e
const/4 p0, 0x0
return-object p0
.end method
.method private static native nativeDumpTrace()V
.end method
.method private static native nativeInit(ILjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ZZIIIZZZZZI[Ljava/lang/String;ZZIIIZZZ)I
.end method
.method static native nativeNotifyAppCrashed()V
.end method
.method private static native nativeNotifyJavaCrashed()V
.end method
.method private static native nativeTestCrash(I)V
.end method
.method private static traceCallback(Ljava/lang/String;Ljava/lang/String;J)V
.registers 7
.line 244
invoke-static {p0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_7
return-void
.line 248
:cond_7
invoke-static {}, Lxcrash/l;->c()Ljava/lang/String;
move-result-object v0
const-string v1, "memory info"
invoke-static {p0, v1, v0}, Lxcrash/j;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Z
.line 251
invoke-static {}, Lxcrash/a;->a()Lxcrash/a;
move-result-object v0
.line 2109
iget-boolean v0, v0, Lxcrash/a;->b:Z
if-eqz v0, :cond_1b
const-string v0, "yes"
goto :goto_1d
:cond_1b
const-string v0, "no"
:goto_1d
const-string v1, "foreground"
.line 251
invoke-static {p0, v1, v0}, Lxcrash/j;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Z
const-wide/16 v0, 0x2
cmp-long v2, p2, v0
if-eqz v2, :cond_4f
.line 254
invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;
move-result-object v0
iget-boolean v0, v0, Lxcrash/NativeHandler;->anrCheckProcessState:Z
if-eqz v0, :cond_4f
.line 255
invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;
move-result-object v0
iget-object v0, v0, Lxcrash/NativeHandler;->ctx:Landroid/content/Context;
invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;
move-result-object v1
iget-wide v1, v1, Lxcrash/NativeHandler;->anrTimeoutMs:J
invoke-static {v0, p0, v1, v2}, Lxcrash/l;->a(Landroid/content/Context;Ljava/lang/String;J)Z
move-result v0
if-nez v0, :cond_4f
.line 256
invoke-static {}, Lxcrash/e;->a()Lxcrash/e;
move-result-object p1
new-instance p2, Ljava/io/File;
invoke-direct {p2, p0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {p1, p2}, Lxcrash/e;->a(Ljava/io/File;)Z
return-void
.line 262
:cond_4f
invoke-static {}, Lxcrash/e;->a()Lxcrash/e;
move-result-object v0
invoke-virtual {v0}, Lxcrash/e;->b()Z
move-result v0
if-nez v0, :cond_5a
return-void
.line 267
:cond_5a
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const/4 v1, 0x0
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result v2
add-int/lit8 v2, v2, -0xd
invoke-virtual {p0, v1, v2}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, ".anr.xcrash"
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
.line 268
new-instance v1, Ljava/io/File;
invoke-direct {v1, p0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 269
new-instance p0, Ljava/io/File;
invoke-direct {p0, v0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 270
invoke-virtual {v1, p0}, Ljava/io/File;->renameTo(Ljava/io/File;)Z
move-result p0
if-nez p0, :cond_8e
.line 271
invoke-static {}, Lxcrash/e;->a()Lxcrash/e;
move-result-object p0
invoke-virtual {p0, v1}, Lxcrash/e;->a(Ljava/io/File;)Z
return-void
:cond_8e
const-wide/16 v1, 0x1
cmp-long p0, p2, v1
if-nez p0, :cond_9b
.line 276
invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;
move-result-object p0
iget-object p0, p0, Lxcrash/NativeHandler;->anrCallback:Lxcrash/f;
goto :goto_a1
.line 277
:cond_9b
invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;
move-result-object p0
iget-object p0, p0, Lxcrash/NativeHandler;->dumpTraceCallBack:Lxcrash/f;
:goto_a1
if-eqz p0, :cond_b3
.line 281
:try_start_a3
invoke-interface {p0, v0, p1}, Lxcrash/f;->a(Ljava/lang/String;Ljava/lang/String;)V
:try_end_a6
.catch Ljava/lang/Exception; {:try_start_a3 .. :try_end_a6} :catch_a7
return-void
:catch_a7
move-exception p0
.line 283
invoke-static {}, Lxcrash/m;->d()Lxcrash/h;
move-result-object p1
const-string p2, "xcrash"
const-string p3, "NativeHandler ANR callback.onCrash failed"
invoke-interface {p1, p2, p3, p0}, Lxcrash/h;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
:cond_b3
return-void
.end method
# virtual methods
.method dumpTrace(Lxcrash/f;)Z
.registers 3
.line 166
iget-boolean v0, p0, Lxcrash/NativeHandler;->initNativeLibOk:Z
if-eqz v0, :cond_f
iget-boolean v0, p0, Lxcrash/NativeHandler;->anrEnable:Z
if-eqz v0, :cond_f
.line 167
iput-object p1, p0, Lxcrash/NativeHandler;->dumpTraceCallBack:Lxcrash/f;
.line 168
invoke-static {}, Lxcrash/NativeHandler;->nativeDumpTrace()V
const/4 p1, 0x1
return p1
:cond_f
const/4 p1, 0x0
return p1
.end method
.method initialize(Landroid/content/Context;Lxcrash/g;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ZZIIIZZZZZI[Ljava/lang/String;Lxcrash/f;ZZZIIIZZLxcrash/f;Z)I
.registers 65
move-object/from16 v1, p0
const-string v2, "NativeHandler init failed"
const-string v3, "xcrash"
if-nez p2, :cond_19
.line 91
:try_start_8
invoke-static {v3}, Ljava/lang/System;->loadLibrary(Ljava/lang/String;)V
:try_end_b
.catchall {:try_start_8 .. :try_end_b} :catchall_c
goto :goto_19
:catchall_c
move-exception v0
move-object v2, v0
.line 93
invoke-static {}, Lxcrash/m;->d()Lxcrash/h;
move-result-object v0
const-string v4, "NativeHandler System.loadLibrary failed"
invoke-interface {v0, v3, v4, v2}, Lxcrash/h;->c(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
const/4 v0, -0x2
return v0
:cond_19
:goto_19
move-object/from16 v0, p1
.line 105
iput-object v0, v1, Lxcrash/NativeHandler;->ctx:Landroid/content/Context;
move/from16 v15, p7
.line 106
iput-boolean v15, v1, Lxcrash/NativeHandler;->crashRethrow:Z
move-object/from16 v4, p18
.line 107
iput-object v4, v1, Lxcrash/NativeHandler;->crashCallback:Lxcrash/f;
move/from16 v14, p19
.line 108
iput-boolean v14, v1, Lxcrash/NativeHandler;->anrEnable:Z
move/from16 v4, p21
.line 109
iput-boolean v4, v1, Lxcrash/NativeHandler;->anrCheckProcessState:Z
move-object/from16 v4, p27
.line 110
iput-object v4, v1, Lxcrash/NativeHandler;->anrCallback:Lxcrash/f;
if-eqz p20, :cond_36
const-wide/16 v4, 0x3a98
goto :goto_38
:cond_36
const-wide/16 v4, 0x7530
.line 111
:goto_38
iput-wide v4, v1, Lxcrash/NativeHandler;->anrTimeoutMs:J
const/16 v35, -0x3
.line 115
:try_start_3c
sget v4, Landroid/os/Build$VERSION;->SDK_INT:I
sget-object v5, Landroid/os/Build$VERSION;->RELEASE:Ljava/lang/String;
.line 118
invoke-static {}, Lxcrash/l;->b()Ljava/lang/String;
move-result-object v6
sget-object v7, Landroid/os/Build;->MANUFACTURER:Ljava/lang/String;
sget-object v8, Landroid/os/Build;->BRAND:Ljava/lang/String;
sget-object v9, Landroid/os/Build;->MODEL:Ljava/lang/String;
sget-object v10, Landroid/os/Build;->FINGERPRINT:Ljava/lang/String;
.line 125
invoke-virtual/range {p1 .. p1}, Landroid/content/Context;->getApplicationInfo()Landroid/content/pm/ApplicationInfo;
move-result-object v0
iget-object v13, v0, Landroid/content/pm/ApplicationInfo;->nativeLibraryDir:Ljava/lang/String;
move-object/from16 v11, p3
move-object/from16 v12, p4
move-object/from16 v14, p5
move/from16 v15, p6
move/from16 v16, p7
move/from16 v17, p8
move/from16 v18, p9
move/from16 v19, p10
move/from16 v20, p11
move/from16 v21, p12
move/from16 v22, p13
move/from16 v23, p14
move/from16 v24, p15
move/from16 v25, p16
move-object/from16 v26, p17
move/from16 v27, p19
move/from16 v28, p20
move/from16 v29, p22
move/from16 v30, p23
move/from16 v31, p24
move/from16 v32, p25
move/from16 v33, p26
move/from16 v34, p28
.line 115
invoke-static/range {v4 .. v34}, Lxcrash/NativeHandler;->nativeInit(ILjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ZZIIIZZZZZI[Ljava/lang/String;ZZIIIZZZ)I
move-result v0
if-eqz v0, :cond_8e
.line 148
invoke-static {}, Lxcrash/m;->d()Lxcrash/h;
move-result-object v0
invoke-interface {v0, v3, v2}, Lxcrash/h;->b(Ljava/lang/String;Ljava/lang/String;)V
return v35
:cond_8e
const/4 v0, 0x1
.line 151
iput-boolean v0, v1, Lxcrash/NativeHandler;->initNativeLibOk:Z
:try_end_91
.catchall {:try_start_3c .. :try_end_91} :catchall_93
const/4 v0, 0x0
return v0
:catchall_93
move-exception v0
.line 154
invoke-static {}, Lxcrash/m;->d()Lxcrash/h;
move-result-object v4
invoke-interface {v4, v3, v2, v0}, Lxcrash/h;->c(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
return v35
.end method
.method notifyJavaCrashed()V
.registers 2
.line 160
iget-boolean v0, p0, Lxcrash/NativeHandler;->initNativeLibOk:Z
if-eqz v0, :cond_b
iget-boolean v0, p0, Lxcrash/NativeHandler;->anrEnable:Z
if-eqz v0, :cond_b
.line 161
invoke-static {}, Lxcrash/NativeHandler;->nativeNotifyJavaCrashed()V
:cond_b
return-void
.end method
.method testNativeCrash(Z)V
.registers 3
.line 175
iget-boolean v0, p0, Lxcrash/NativeHandler;->initNativeLibOk:Z
if-eqz v0, :cond_7
.line 176
invoke-static {p1}, Lxcrash/NativeHandler;->nativeTestCrash(I)V
:cond_7
return-void
.end method