public class com.android.server.BootReceiver extends android.content.BroadcastReceiver
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: com.android.server.BootReceiver
  super_class: android.content.BroadcastReceiver
{
  private static final java.lang.String TAG;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "BootReceiver"

  private static final int LOG_SIZE;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.io.File TOMBSTONE_DIR;
    descriptor: Ljava/io/File;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.String TAG_TOMBSTONE;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "SYSTEM_TOMBSTONE"

  private static final java.lang.String OLD_UPDATER_PACKAGE;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "com.google.android.systemupdater"

  private static final java.lang.String OLD_UPDATER_CLASS;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "com.google.android.systemupdater.SystemUpdateReceiver"

  private static android.os.FileObserver sTombstoneObserver;
    descriptor: Landroid/os/FileObserver;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static final java.lang.String LOG_FILES_FILE;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "log-files.xml"

  private static final android.util.AtomicFile sFile;
    descriptor: Landroid/util/AtomicFile;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.String LAST_HEADER_FILE;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "last-header.txt"

  private static final java.io.File lastHeaderFile;
    descriptor: Ljava/io/File;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.String FS_STAT_PATTERN;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "fs_stat,[^,]*/([^/,]+),(0x[0-9a-fA-F]+)"

  private static final int FS_STAT_FS_FIXED;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1024

  private static final java.lang.String FSCK_PASS_PATTERN;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "Pass ([1-9]E?):"

  private static final java.lang.String FSCK_TREE_OPTIMIZATION_PATTERN;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "Inode [0-9]+ extent tree.*could be shorter"

  private static final java.lang.String FSCK_FS_MODIFIED;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "FILE SYSTEM WAS MODIFIED"

  private static final java.lang.String[] MOUNT_DURATION_PROPS_POSTFIX;
    descriptor: [Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.String[] LAST_KMSG_FILES;
    descriptor: [Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.String LAST_SHUTDOWN_TIME_PATTERN;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "powerctl_shutdown_time_ms:([0-9]+):([0-9]+)"

  private static final int UMOUNT_STATUS_NOT_AVAILABLE;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 4

  private static final java.lang.String SHUTDOWN_METRICS_FILE;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "/data/system/shutdown-metrics.txt"

  private static final java.lang.String SHUTDOWN_TRON_METRICS_PREFIX;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "shutdown_"

  private static final java.lang.String METRIC_SYSTEM_SERVER;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "shutdown_system_server"

  private static final java.lang.String METRIC_SHUTDOWN_TIME_START;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "begin_shutdown"

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=6, locals=0, args_size=0
         0: .line 72
            ldc "ro.debuggable"
            iconst_0
            invokestatic android.os.SystemProperties.getInt:(Ljava/lang/String;I)I
            iconst_1
            if_icmpne 1
            ldc 98304
            goto 2
      StackMap locals:
      StackMap stack:
         1: ldc 65536
         2: .line 71
      StackMap locals:
      StackMap stack: int
            putstatic com.android.server.BootReceiver.LOG_SIZE:I
         3: .line 74
            new java.io.File
            dup
            ldc "/data/tombstones"
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            putstatic com.android.server.BootReceiver.TOMBSTONE_DIR:Ljava/io/File;
         4: .line 86
            aconst_null
            putstatic com.android.server.BootReceiver.sTombstoneObserver:Landroid/os/FileObserver;
         5: .line 89
            new android.util.AtomicFile
            dup
            new java.io.File
            dup
         6: .line 90
            invokestatic android.os.Environment.getDataSystemDirectory:()Ljava/io/File;
            ldc "log-files.xml"
            invokespecial java.io.File.<init>:(Ljava/io/File;Ljava/lang/String;)V
            ldc "log-files"
         7: .line 89
            invokespecial android.util.AtomicFile.<init>:(Ljava/io/File;Ljava/lang/String;)V
            putstatic com.android.server.BootReceiver.sFile:Landroid/util/AtomicFile;
         8: .line 92
            new java.io.File
            dup
         9: .line 93
            invokestatic android.os.Environment.getDataSystemDirectory:()Ljava/io/File;
            ldc "last-header.txt"
        10: .line 92
            invokespecial java.io.File.<init>:(Ljava/io/File;Ljava/lang/String;)V
            putstatic com.android.server.BootReceiver.lastHeaderFile:Ljava/io/File;
        11: .line 104
            iconst_3
            anewarray java.lang.String
            dup
            iconst_0
            ldc "early"
            aastore
            dup
            iconst_1
            ldc "default"
            aastore
            dup
            iconst_2
            ldc "late"
            aastore
        12: .line 103
            putstatic com.android.server.BootReceiver.MOUNT_DURATION_PROPS_POSTFIX:[Ljava/lang/String;
        13: .line 107
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
            ldc "/sys/fs/pstore/console-ramoops"
            aastore
            dup
            iconst_1
            ldc "/proc/last_kmsg"
            aastore
        14: .line 106
            putstatic com.android.server.BootReceiver.LAST_KMSG_FILES:[Ljava/lang/String;
        15: .line 118
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.android.server.BootReceiver this
         0: .line 66
            aload 0 /* this */
            invokespecial android.content.BroadcastReceiver.<init>:()V
            return
        end local 0 // com.android.server.BootReceiver this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/android/server/BootReceiver;

  public void onReceive(android.content.Context, android.content.Intent);
    descriptor: (Landroid/content/Context;Landroid/content/Intent;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // com.android.server.BootReceiver this
        start local 1 // android.content.Context context
        start local 2 // android.content.Intent intent
         0: .line 123
            new com.android.server.BootReceiver$1
            dup
            aload 0 /* this */
            aload 1 /* context */
            invokespecial com.android.server.BootReceiver$1.<init>:(Lcom/android/server/BootReceiver;Landroid/content/Context;)V
         1: .line 146
            invokevirtual com.android.server.BootReceiver$1.start:()V
         2: .line 147
            return
        end local 2 // android.content.Intent intent
        end local 1 // android.content.Context context
        end local 0 // com.android.server.BootReceiver this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lcom/android/server/BootReceiver;
            0    3     1  context  Landroid/content/Context;
            0    3     2   intent  Landroid/content/Intent;
    MethodParameters:
         Name  Flags
      context  final
      intent   

  private void removeOldUpdatePackages(android.content.Context);
    descriptor: (Landroid/content/Context;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.android.server.BootReceiver this
        start local 1 // android.content.Context context
         0: .line 150
            aload 1 /* context */
            ldc "com.google.android.systemupdater"
            ldc "com.google.android.systemupdater.SystemUpdateReceiver"
            invokestatic android.provider.Downloads.removeAllDownloadsByPackage:(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)V
         1: .line 151
            return
        end local 1 // android.content.Context context
        end local 0 // com.android.server.BootReceiver this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lcom/android/server/BootReceiver;
            0    2     1  context  Landroid/content/Context;
    MethodParameters:
         Name  Flags
      context  

  private java.lang.String getPreviousBootHeaders();
    descriptor: ()Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.android.server.BootReceiver this
         0: .line 155
            getstatic com.android.server.BootReceiver.lastHeaderFile:Ljava/io/File;
            iconst_0
            aconst_null
            invokestatic android.os.FileUtils.readTextFile:(Ljava/io/File;ILjava/lang/String;)Ljava/lang/String;
         1: areturn
         2: .line 156
      StackMap locals:
      StackMap stack: java.io.IOException
            pop
         3: .line 157
            aconst_null
            areturn
        end local 0 // com.android.server.BootReceiver this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lcom/android/server/BootReceiver;
      Exception table:
        from    to  target  type
           0     1       2  Class java.io.IOException

  private java.lang.String getCurrentBootHeaders();
    descriptor: ()Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // com.android.server.BootReceiver this
         0: .line 162
            new java.lang.StringBuilder
            dup
            sipush 512
            invokespecial java.lang.StringBuilder.<init>:(I)V
         1: .line 163
            ldc "Build: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic android.os.Build.FINGERPRINT:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         2: .line 164
            ldc "Hardware: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic android.os.Build.BOARD:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         3: .line 165
            ldc "Revision: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         4: .line 166
            ldc "ro.revision"
            ldc ""
            invokestatic android.os.SystemProperties.get:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         5: .line 167
            ldc "Bootloader: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic android.os.Build.BOOTLOADER:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         6: .line 168
            ldc "Radio: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokestatic android.os.Build.getRadioVersion:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         7: .line 169
            ldc "Kernel: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         8: .line 170
            new java.io.File
            dup
            ldc "/proc/version"
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            sipush 1024
            ldc "...\n"
            invokestatic android.os.FileUtils.readTextFile:(Ljava/io/File;ILjava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         9: .line 171
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        10: .line 162
            areturn
        end local 0 // com.android.server.BootReceiver this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lcom/android/server/BootReceiver;
    Exceptions:
      throws java.io.IOException

  private java.lang.String getBootHeadersToLogAndUpdate();
    descriptor: ()Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // com.android.server.BootReceiver this
         0: .line 176
            aload 0 /* this */
            invokevirtual com.android.server.BootReceiver.getPreviousBootHeaders:()Ljava/lang/String;
            astore 1 /* oldHeaders */
        start local 1 // java.lang.String oldHeaders
         1: .line 177
            aload 0 /* this */
            invokevirtual com.android.server.BootReceiver.getCurrentBootHeaders:()Ljava/lang/String;
            astore 2 /* newHeaders */
        start local 2 // java.lang.String newHeaders
         2: .line 180
            getstatic com.android.server.BootReceiver.lastHeaderFile:Ljava/io/File;
            aload 2 /* newHeaders */
            invokestatic android.os.FileUtils.stringToFile:(Ljava/io/File;Ljava/lang/String;)V
         3: .line 181
            goto 6
      StackMap locals: com.android.server.BootReceiver java.lang.String java.lang.String
      StackMap stack: java.io.IOException
         4: astore 3 /* e */
        start local 3 // java.io.IOException e
         5: .line 182
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "Error writing "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            getstatic com.android.server.BootReceiver.lastHeaderFile:Ljava/io/File;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 3 /* e */
            invokestatic android.util.Slog.e:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
            pop
        end local 3 // java.io.IOException e
         6: .line 185
      StackMap locals:
      StackMap stack:
            aload 1 /* oldHeaders */
            ifnonnull 8
         7: .line 188
            new java.lang.StringBuilder
            dup
            ldc "isPrevious: false\n"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* newHeaders */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
         8: .line 191
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            ldc "isPrevious: true\n"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* oldHeaders */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 2 // java.lang.String newHeaders
        end local 1 // java.lang.String oldHeaders
        end local 0 // com.android.server.BootReceiver this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    9     0        this  Lcom/android/server/BootReceiver;
            1    9     1  oldHeaders  Ljava/lang/String;
            2    9     2  newHeaders  Ljava/lang/String;
            5    6     3           e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           2     3       4  Class java.io.IOException
    Exceptions:
      throws java.io.IOException

  private void logBootEvents(android.content.Context);
    descriptor: (Landroid/content/Context;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=10, args_size=2
        start local 0 // com.android.server.BootReceiver this
        start local 1 // android.content.Context ctx
         0: .line 195
            aload 1 /* ctx */
            ldc "dropbox"
            invokevirtual android.content.Context.getSystemService:(Ljava/lang/String;)Ljava/lang/Object;
            checkcast android.os.DropBoxManager
            astore 2 /* db */
        start local 2 // android.os.DropBoxManager db
         1: .line 196
            aload 0 /* this */
            invokevirtual com.android.server.BootReceiver.getBootHeadersToLogAndUpdate:()Ljava/lang/String;
            astore 3 /* headers */
        start local 3 // java.lang.String headers
         2: .line 197
            ldc "ro.boot.bootreason"
            aconst_null
            invokestatic android.os.SystemProperties.get:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
            astore 4 /* bootReason */
        start local 4 // java.lang.String bootReason
         3: .line 199
            aload 1 /* ctx */
            invokestatic android.os.RecoverySystem.handleAftermath:(Landroid/content/Context;)Ljava/lang/String;
            astore 5 /* recovery */
        start local 5 // java.lang.String recovery
         4: .line 200
            aload 5 /* recovery */
            ifnull 6
            aload 2 /* db */
            ifnull 6
         5: .line 201
            aload 2 /* db */
            ldc "SYSTEM_RECOVERY_LOG"
            new java.lang.StringBuilder
            dup
            aload 3 /* headers */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* recovery */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual android.os.DropBoxManager.addText:(Ljava/lang/String;Ljava/lang/String;)V
         6: .line 204
      StackMap locals: com.android.server.BootReceiver android.content.Context android.os.DropBoxManager java.lang.String java.lang.String java.lang.String
      StackMap stack:
            ldc ""
            astore 6 /* lastKmsgFooter */
        start local 6 // java.lang.String lastKmsgFooter
         7: .line 205
            aload 4 /* bootReason */
            ifnull 14
         8: .line 206
            new java.lang.StringBuilder
            dup
            sipush 512
            invokespecial java.lang.StringBuilder.<init>:(I)V
         9: .line 207
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        10: .line 208
            ldc "Boot info:\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        11: .line 209
            ldc "Last boot reason: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 4 /* bootReason */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        12: .line 210
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 206
            astore 6 /* lastKmsgFooter */
        14: .line 213
      StackMap locals: java.lang.String
      StackMap stack:
            invokestatic com.android.server.BootReceiver.readTimestamps:()Ljava/util/HashMap;
            astore 7 /* timestamps */
        start local 7 // java.util.HashMap timestamps
        15: .line 215
            ldc "ro.runtime.firstboot"
            lconst_0
            invokestatic android.os.SystemProperties.getLong:(Ljava/lang/String;J)J
            lconst_0
            lcmp
            ifne 37
        16: .line 216
            invokestatic android.os.storage.StorageManager.inCryptKeeperBounce:()Z
            ifne 19
        17: .line 221
            invokestatic java.lang.System.currentTimeMillis:()J
            invokestatic java.lang.Long.toString:(J)Ljava/lang/String;
            astore 8 /* now */
        start local 8 // java.lang.String now
        18: .line 222
            ldc "ro.runtime.firstboot"
            aload 8 /* now */
            invokestatic android.os.SystemProperties.set:(Ljava/lang/String;Ljava/lang/String;)V
        end local 8 // java.lang.String now
        19: .line 224
      StackMap locals: java.util.HashMap
      StackMap stack:
            aload 2 /* db */
            ifnull 20
            aload 2 /* db */
            ldc "SYSTEM_BOOT"
            aload 3 /* headers */
            invokevirtual android.os.DropBoxManager.addText:(Ljava/lang/String;Ljava/lang/String;)V
        20: .line 227
      StackMap locals:
      StackMap stack:
            aload 2 /* db */
            aload 7 /* timestamps */
            aload 3 /* headers */
            aload 6 /* lastKmsgFooter */
        21: .line 228
            ldc "/proc/last_kmsg"
            getstatic com.android.server.BootReceiver.LOG_SIZE:I
            ineg
            ldc "SYSTEM_LAST_KMSG"
        22: .line 227
            invokestatic com.android.server.BootReceiver.addFileWithFootersToDropBox:(Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)V
        23: .line 229
            aload 2 /* db */
            aload 7 /* timestamps */
            aload 3 /* headers */
            aload 6 /* lastKmsgFooter */
        24: .line 230
            ldc "/sys/fs/pstore/console-ramoops"
            getstatic com.android.server.BootReceiver.LOG_SIZE:I
            ineg
            ldc "SYSTEM_LAST_KMSG"
        25: .line 229
            invokestatic com.android.server.BootReceiver.addFileWithFootersToDropBox:(Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)V
        26: .line 231
            aload 2 /* db */
            aload 7 /* timestamps */
            aload 3 /* headers */
            aload 6 /* lastKmsgFooter */
        27: .line 232
            ldc "/sys/fs/pstore/console-ramoops-0"
            getstatic com.android.server.BootReceiver.LOG_SIZE:I
            ineg
            ldc "SYSTEM_LAST_KMSG"
        28: .line 231
            invokestatic com.android.server.BootReceiver.addFileWithFootersToDropBox:(Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)V
        29: .line 233
            aload 2 /* db */
            aload 7 /* timestamps */
            aload 3 /* headers */
            ldc "/cache/recovery/log"
            getstatic com.android.server.BootReceiver.LOG_SIZE:I
            ineg
        30: .line 234
            ldc "SYSTEM_RECOVERY_LOG"
        31: .line 233
            invokestatic com.android.server.BootReceiver.addFileToDropBox:(Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)V
        32: .line 235
            aload 2 /* db */
            aload 7 /* timestamps */
            aload 3 /* headers */
            ldc "/cache/recovery/last_kmsg"
        33: .line 236
            getstatic com.android.server.BootReceiver.LOG_SIZE:I
            ineg
            ldc "SYSTEM_RECOVERY_KMSG"
        34: .line 235
            invokestatic com.android.server.BootReceiver.addFileToDropBox:(Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)V
        35: .line 237
            aload 2 /* db */
            aload 7 /* timestamps */
            aload 3 /* headers */
            getstatic com.android.server.BootReceiver.LOG_SIZE:I
            ineg
            ldc "SYSTEM_AUDIT"
            invokestatic com.android.server.BootReceiver.addAuditErrorsToDropBox:(Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;ILjava/lang/String;)V
        36: .line 238
            goto 38
        37: .line 239
      StackMap locals:
      StackMap stack:
            aload 2 /* db */
            ifnull 38
            aload 2 /* db */
            ldc "SYSTEM_RESTART"
            aload 3 /* headers */
            invokevirtual android.os.DropBoxManager.addText:(Ljava/lang/String;Ljava/lang/String;)V
        38: .line 243
      StackMap locals:
      StackMap stack:
            invokestatic com.android.server.BootReceiver.logFsShutdownTime:()V
        39: .line 244
            invokestatic com.android.server.BootReceiver.logFsMountTime:()V
        40: .line 245
            aload 2 /* db */
            aload 7 /* timestamps */
            aload 3 /* headers */
            getstatic com.android.server.BootReceiver.LOG_SIZE:I
            ineg
            ldc "SYSTEM_FSCK"
            invokestatic com.android.server.BootReceiver.addFsckErrorsToDropBoxAndLogFsStat:(Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;ILjava/lang/String;)V
        41: .line 246
            invokestatic com.android.server.BootReceiver.logSystemServerShutdownTimeMetrics:()V
        42: .line 249
            getstatic com.android.server.BootReceiver.TOMBSTONE_DIR:Ljava/io/File;
            invokevirtual java.io.File.listFiles:()[Ljava/io/File;
            astore 8 /* tombstoneFiles */
        start local 8 // java.io.File[] tombstoneFiles
        43: .line 250
            iconst_0
            istore 9 /* i */
        start local 9 // int i
        44: goto 50
        45: .line 251
      StackMap locals: java.io.File[] int
      StackMap stack:
            aload 8 /* tombstoneFiles */
            iload 9 /* i */
            aaload
            invokevirtual java.io.File.isFile:()Z
            ifeq 49
        46: .line 252
            aload 2 /* db */
            aload 7 /* timestamps */
            aload 3 /* headers */
            aload 8 /* tombstoneFiles */
            iload 9 /* i */
            aaload
            invokevirtual java.io.File.getPath:()Ljava/lang/String;
        47: .line 253
            getstatic com.android.server.BootReceiver.LOG_SIZE:I
            ldc "SYSTEM_TOMBSTONE"
        48: .line 252
            invokestatic com.android.server.BootReceiver.addFileToDropBox:(Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)V
        49: .line 250
      StackMap locals:
      StackMap stack:
            iinc 9 /* i */ 1
      StackMap locals:
      StackMap stack:
        50: aload 8 /* tombstoneFiles */
            ifnull 51
            iload 9 /* i */
            aload 8 /* tombstoneFiles */
            arraylength
            if_icmplt 45
        end local 9 // int i
        51: .line 257
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 7 /* timestamps */
            invokevirtual com.android.server.BootReceiver.writeTimestamps:(Ljava/util/HashMap;)V
        52: .line 261
            new com.android.server.BootReceiver$2
            dup
            aload 0 /* this */
            getstatic com.android.server.BootReceiver.TOMBSTONE_DIR:Ljava/io/File;
            invokevirtual java.io.File.getPath:()Ljava/lang/String;
            sipush 256
            aload 2 /* db */
            aload 3 /* headers */
            invokespecial com.android.server.BootReceiver$2.<init>:(Lcom/android/server/BootReceiver;Ljava/lang/String;ILandroid/os/DropBoxManager;Ljava/lang/String;)V
            putstatic com.android.server.BootReceiver.sTombstoneObserver:Landroid/os/FileObserver;
        53: .line 278
            getstatic com.android.server.BootReceiver.sTombstoneObserver:Landroid/os/FileObserver;
            invokevirtual android.os.FileObserver.startWatching:()V
        54: .line 279
            return
        end local 8 // java.io.File[] tombstoneFiles
        end local 7 // java.util.HashMap timestamps
        end local 6 // java.lang.String lastKmsgFooter
        end local 5 // java.lang.String recovery
        end local 4 // java.lang.String bootReason
        end local 3 // java.lang.String headers
        end local 2 // android.os.DropBoxManager db
        end local 1 // android.content.Context ctx
        end local 0 // com.android.server.BootReceiver this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   55     0            this  Lcom/android/server/BootReceiver;
            0   55     1             ctx  Landroid/content/Context;
            1   55     2              db  Landroid/os/DropBoxManager;
            2   55     3         headers  Ljava/lang/String;
            3   55     4      bootReason  Ljava/lang/String;
            4   55     5        recovery  Ljava/lang/String;
            7   55     6  lastKmsgFooter  Ljava/lang/String;
           15   55     7      timestamps  Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Long;>;
           18   19     8             now  Ljava/lang/String;
           43   55     8  tombstoneFiles  [Ljava/io/File;
           44   51     9               i  I
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      ctx   

  private static void addFileToDropBox(android.os.DropBoxManager, java.util.HashMap<java.lang.String, java.lang.Long>, java.lang.String, java.lang.String, int, java.lang.String);
    descriptor: (Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=6, args_size=6
        start local 0 // android.os.DropBoxManager db
        start local 1 // java.util.HashMap timestamps
        start local 2 // java.lang.String headers
        start local 3 // java.lang.String filename
        start local 4 // int maxSize
        start local 5 // java.lang.String tag
         0: .line 284
            aload 0 /* db */
            aload 1 /* timestamps */
            aload 2 /* headers */
            ldc ""
            aload 3 /* filename */
            iload 4 /* maxSize */
            aload 5 /* tag */
            invokestatic com.android.server.BootReceiver.addFileWithFootersToDropBox:(Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)V
         1: .line 285
            return
        end local 5 // java.lang.String tag
        end local 4 // int maxSize
        end local 3 // java.lang.String filename
        end local 2 // java.lang.String headers
        end local 1 // java.util.HashMap timestamps
        end local 0 // android.os.DropBoxManager db
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0          db  Landroid/os/DropBoxManager;
            0    2     1  timestamps  Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Long;>;
            0    2     2     headers  Ljava/lang/String;
            0    2     3    filename  Ljava/lang/String;
            0    2     4     maxSize  I
            0    2     5         tag  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    Signature: (Landroid/os/DropBoxManager;Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Long;>;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)V
    MethodParameters:
            Name  Flags
      db          
      timestamps  
      headers     
      filename    
      maxSize     
      tag         

  private static void addFileWithFootersToDropBox(android.os.DropBoxManager, java.util.HashMap<java.lang.String, java.lang.Long>, java.lang.String, java.lang.String, java.lang.String, int, java.lang.String);
    descriptor: (Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=12, args_size=7
        start local 0 // android.os.DropBoxManager db
        start local 1 // java.util.HashMap timestamps
        start local 2 // java.lang.String headers
        start local 3 // java.lang.String footers
        start local 4 // java.lang.String filename
        start local 5 // int maxSize
        start local 6 // java.lang.String tag
         0: .line 291
            aload 0 /* db */
            ifnull 1
            aload 0 /* db */
            aload 6 /* tag */
            invokevirtual android.os.DropBoxManager.isTagEnabled:(Ljava/lang/String;)Z
            ifne 2
      StackMap locals:
      StackMap stack:
         1: return
         2: .line 293
      StackMap locals:
      StackMap stack:
            new java.io.File
            dup
            aload 4 /* filename */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 7 /* file */
        start local 7 // java.io.File file
         3: .line 294
            aload 7 /* file */
            invokevirtual java.io.File.lastModified:()J
            lstore 8 /* fileTime */
        start local 8 // long fileTime
         4: .line 295
            lload 8 /* fileTime */
            lconst_0
            lcmp
            ifgt 5
            return
         5: .line 297
      StackMap locals: java.io.File long
      StackMap stack:
            aload 1 /* timestamps */
            aload 4 /* filename */
            invokevirtual java.util.HashMap.containsKey:(Ljava/lang/Object;)Z
            ifeq 7
            aload 1 /* timestamps */
            aload 4 /* filename */
            invokevirtual java.util.HashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            lload 8 /* fileTime */
            lcmp
            ifne 7
         6: .line 298
            return
         7: .line 301
      StackMap locals:
      StackMap stack:
            aload 1 /* timestamps */
            aload 4 /* filename */
            lload 8 /* fileTime */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         8: .line 304
            aload 7 /* file */
            iload 5 /* maxSize */
            ldc "[[TRUNCATED]]\n"
            invokestatic android.os.FileUtils.readTextFile:(Ljava/io/File;ILjava/lang/String;)Ljava/lang/String;
            astore 10 /* fileContents */
        start local 10 // java.lang.String fileContents
         9: .line 305
            new java.lang.StringBuilder
            dup
            aload 2 /* headers */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 10 /* fileContents */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* footers */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 11 /* text */
        start local 11 // java.lang.String text
        10: .line 307
            aload 6 /* tag */
            ldc "SYSTEM_TOMBSTONE"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 12
            aload 10 /* fileContents */
            ldc ">>> system_server <<<"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 12
        11: .line 308
            aload 0 /* db */
            ldc "system_server_native_crash"
            aload 11 /* text */
            aload 4 /* filename */
            iload 5 /* maxSize */
            invokestatic com.android.server.BootReceiver.addTextToDropBox:(Landroid/os/DropBoxManager;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;I)V
        12: .line 310
      StackMap locals: java.lang.String java.lang.String
      StackMap stack:
            aload 0 /* db */
            aload 6 /* tag */
            aload 11 /* text */
            aload 4 /* filename */
            iload 5 /* maxSize */
            invokestatic com.android.server.BootReceiver.addTextToDropBox:(Landroid/os/DropBoxManager;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;I)V
        13: .line 311
            return
        end local 11 // java.lang.String text
        end local 10 // java.lang.String fileContents
        end local 8 // long fileTime
        end local 7 // java.io.File file
        end local 6 // java.lang.String tag
        end local 5 // int maxSize
        end local 4 // java.lang.String filename
        end local 3 // java.lang.String footers
        end local 2 // java.lang.String headers
        end local 1 // java.util.HashMap timestamps
        end local 0 // android.os.DropBoxManager db
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   14     0            db  Landroid/os/DropBoxManager;
            0   14     1    timestamps  Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Long;>;
            0   14     2       headers  Ljava/lang/String;
            0   14     3       footers  Ljava/lang/String;
            0   14     4      filename  Ljava/lang/String;
            0   14     5       maxSize  I
            0   14     6           tag  Ljava/lang/String;
            3   14     7          file  Ljava/io/File;
            4   14     8      fileTime  J
            9   14    10  fileContents  Ljava/lang/String;
           10   14    11          text  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    Signature: (Landroid/os/DropBoxManager;Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Long;>;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)V
    MethodParameters:
            Name  Flags
      db          
      timestamps  
      headers     
      footers     
      filename    
      maxSize     
      tag         

  private static void addTextToDropBox(android.os.DropBoxManager, java.lang.String, java.lang.String, java.lang.String, int);
    descriptor: (Landroid/os/DropBoxManager;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;I)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=5, args_size=5
         0: .line 317
            new java.lang.Error
            dup
            ldc "Unresolved compilation problem: \n\tDropboxLogTags cannot be resolved to a variable\n"
            invokespecial java.lang.Error.<init>:(Ljava/lang/String;)V
            athrow
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    MethodParameters:
          Name  Flags
      db        
      tag       
      text      
      filename  
      maxSize   

  private static void addAuditErrorsToDropBox(android.os.DropBoxManager, java.util.HashMap<java.lang.String, java.lang.Long>, java.lang.String, int, java.lang.String);
    descriptor: (Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;ILjava/lang/String;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=14, args_size=5
        start local 0 // android.os.DropBoxManager db
        start local 1 // java.util.HashMap timestamps
        start local 2 // java.lang.String headers
        start local 3 // int maxSize
        start local 4 // java.lang.String tag
         0: .line 323
            aload 0 /* db */
            ifnull 1
            aload 0 /* db */
            aload 4 /* tag */
            invokevirtual android.os.DropBoxManager.isTagEnabled:(Ljava/lang/String;)Z
            ifne 2
      StackMap locals:
      StackMap stack:
         1: return
         2: .line 324
      StackMap locals:
      StackMap stack:
            ldc "BootReceiver"
            ldc "Copying audit failures to DropBox"
            invokestatic android.util.Slog.i:(Ljava/lang/String;Ljava/lang/String;)I
            pop
         3: .line 326
            new java.io.File
            dup
            ldc "/proc/last_kmsg"
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 5 /* file */
        start local 5 // java.io.File file
         4: .line 327
            aload 5 /* file */
            invokevirtual java.io.File.lastModified:()J
            lstore 6 /* fileTime */
        start local 6 // long fileTime
         5: .line 328
            lload 6 /* fileTime */
            lconst_0
            lcmp
            ifgt 11
         6: .line 329
            new java.io.File
            dup
            ldc "/sys/fs/pstore/console-ramoops"
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 5 /* file */
         7: .line 330
            aload 5 /* file */
            invokevirtual java.io.File.lastModified:()J
            lstore 6 /* fileTime */
         8: .line 331
            lload 6 /* fileTime */
            lconst_0
            lcmp
            ifgt 11
         9: .line 332
            new java.io.File
            dup
            ldc "/sys/fs/pstore/console-ramoops-0"
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 5 /* file */
        10: .line 333
            aload 5 /* file */
            invokevirtual java.io.File.lastModified:()J
            lstore 6 /* fileTime */
        11: .line 337
      StackMap locals: java.io.File long
      StackMap stack:
            lload 6 /* fileTime */
            lconst_0
            lcmp
            ifgt 12
            return
        12: .line 339
      StackMap locals:
      StackMap stack:
            aload 1 /* timestamps */
            aload 4 /* tag */
            invokevirtual java.util.HashMap.containsKey:(Ljava/lang/Object;)Z
            ifeq 14
            aload 1 /* timestamps */
            aload 4 /* tag */
            invokevirtual java.util.HashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            lload 6 /* fileTime */
            lcmp
            ifne 14
        13: .line 340
            return
        14: .line 343
      StackMap locals:
      StackMap stack:
            aload 1 /* timestamps */
            aload 4 /* tag */
            lload 6 /* fileTime */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        15: .line 345
            aload 5 /* file */
            iload 3 /* maxSize */
            ldc "[[TRUNCATED]]\n"
            invokestatic android.os.FileUtils.readTextFile:(Ljava/io/File;ILjava/lang/String;)Ljava/lang/String;
            astore 8 /* log */
        start local 8 // java.lang.String log
        16: .line 346
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 9 /* sb */
        start local 9 // java.lang.StringBuilder sb
        17: .line 347
            aload 8 /* log */
            ldc "\n"
            invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
            dup
            astore 13
            arraylength
            istore 12
            iconst_0
            istore 11
            goto 22
      StackMap locals: android.os.DropBoxManager java.util.HashMap java.lang.String int java.lang.String java.io.File long java.lang.String java.lang.StringBuilder top int int java.lang.String[]
      StackMap stack:
        18: aload 13
            iload 11
            aaload
            astore 10 /* line */
        start local 10 // java.lang.String line
        19: .line 348
            aload 10 /* line */
            ldc "audit"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 21
        20: .line 349
            aload 9 /* sb */
            new java.lang.StringBuilder
            dup
            aload 10 /* line */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 10 // java.lang.String line
        21: .line 347
      StackMap locals:
      StackMap stack:
            iinc 11 1
      StackMap locals:
      StackMap stack:
        22: iload 11
            iload 12
            if_icmplt 18
        23: .line 352
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "Copied "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 9 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.String.length:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " worth of audits to DropBox"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic android.util.Slog.i:(Ljava/lang/String;Ljava/lang/String;)I
            pop
        24: .line 353
            aload 0 /* db */
            aload 4 /* tag */
            new java.lang.StringBuilder
            dup
            aload 2 /* headers */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 9 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual android.os.DropBoxManager.addText:(Ljava/lang/String;Ljava/lang/String;)V
        25: .line 354
            return
        end local 9 // java.lang.StringBuilder sb
        end local 8 // java.lang.String log
        end local 6 // long fileTime
        end local 5 // java.io.File file
        end local 4 // java.lang.String tag
        end local 3 // int maxSize
        end local 2 // java.lang.String headers
        end local 1 // java.util.HashMap timestamps
        end local 0 // android.os.DropBoxManager db
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   26     0          db  Landroid/os/DropBoxManager;
            0   26     1  timestamps  Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Long;>;
            0   26     2     headers  Ljava/lang/String;
            0   26     3     maxSize  I
            0   26     4         tag  Ljava/lang/String;
            4   26     5        file  Ljava/io/File;
            5   26     6    fileTime  J
           16   26     8         log  Ljava/lang/String;
           17   26     9          sb  Ljava/lang/StringBuilder;
           19   21    10        line  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    Signature: (Landroid/os/DropBoxManager;Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Long;>;Ljava/lang/String;ILjava/lang/String;)V
    MethodParameters:
            Name  Flags
      db          
      timestamps  
      headers     
      maxSize     
      tag         

  private static void addFsckErrorsToDropBoxAndLogFsStat(android.os.DropBoxManager, java.util.HashMap<java.lang.String, java.lang.Long>, java.lang.String, int, java.lang.String);
    descriptor: (Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;ILjava/lang/String;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=20, args_size=5
        start local 0 // android.os.DropBoxManager db
        start local 1 // java.util.HashMap timestamps
        start local 2 // java.lang.String headers
        start local 3 // int maxSize
        start local 4 // java.lang.String tag
         0: .line 359
            iconst_1
            istore 5 /* uploadEnabled */
        start local 5 // boolean uploadEnabled
         1: .line 360
            aload 0 /* db */
            ifnull 2
            aload 0 /* db */
            aload 4 /* tag */
            invokevirtual android.os.DropBoxManager.isTagEnabled:(Ljava/lang/String;)Z
            ifne 3
         2: .line 361
      StackMap locals: int
      StackMap stack:
            iconst_0
            istore 5 /* uploadEnabled */
         3: .line 363
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 6 /* uploadNeeded */
        start local 6 // boolean uploadNeeded
         4: .line 364
            ldc "BootReceiver"
            ldc "Checking for fsck errors"
            invokestatic android.util.Slog.i:(Ljava/lang/String;Ljava/lang/String;)I
            pop
         5: .line 366
            new java.io.File
            dup
            ldc "/dev/fscklogs/log"
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 7 /* file */
        start local 7 // java.io.File file
         6: .line 367
            aload 7 /* file */
            invokevirtual java.io.File.lastModified:()J
            lstore 8 /* fileTime */
        start local 8 // long fileTime
         7: .line 368
            lload 8 /* fileTime */
            lconst_0
            lcmp
            ifgt 8
            return
         8: .line 370
      StackMap locals: int java.io.File long
      StackMap stack:
            aload 7 /* file */
            iload 3 /* maxSize */
            ldc "[[TRUNCATED]]\n"
            invokestatic android.os.FileUtils.readTextFile:(Ljava/io/File;ILjava/lang/String;)Ljava/lang/String;
            astore 10 /* log */
        start local 10 // java.lang.String log
         9: .line 371
            ldc "fs_stat,[^,]*/([^/,]+),(0x[0-9a-fA-F]+)"
            invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
            astore 11 /* pattern */
        start local 11 // java.util.regex.Pattern pattern
        10: .line 372
            aload 10 /* log */
            ldc "\n"
            invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
            astore 12 /* lines */
        start local 12 // java.lang.String[] lines
        11: .line 373
            iconst_0
            istore 13 /* lineNumber */
        start local 13 // int lineNumber
        12: .line 374
            iconst_0
            istore 14 /* lastFsStatLineNumber */
        start local 14 // int lastFsStatLineNumber
        13: .line 375
            aload 12 /* lines */
            dup
            astore 18
            arraylength
            istore 17
            iconst_0
            istore 16
            goto 27
      StackMap locals: android.os.DropBoxManager java.util.HashMap java.lang.String int java.lang.String int int java.io.File long java.lang.String java.util.regex.Pattern java.lang.String[] int int top int int java.lang.String[]
      StackMap stack:
        14: aload 18
            iload 16
            aaload
            astore 15 /* line */
        start local 15 // java.lang.String line
        15: .line 376
            aload 15 /* line */
            ldc "FILE SYSTEM WAS MODIFIED"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 18
        16: .line 377
            iconst_1
            istore 6 /* uploadNeeded */
        17: .line 378
            goto 25
      StackMap locals: android.os.DropBoxManager java.util.HashMap java.lang.String int java.lang.String int int java.io.File long java.lang.String java.util.regex.Pattern java.lang.String[] int int java.lang.String int int java.lang.String[]
      StackMap stack:
        18: aload 15 /* line */
            ldc "fs_stat"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 25
        19: .line 379
            aload 11 /* pattern */
            aload 15 /* line */
            invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
            astore 19 /* matcher */
        start local 19 // java.util.regex.Matcher matcher
        20: .line 380
            aload 19 /* matcher */
            invokevirtual java.util.regex.Matcher.find:()Z
            ifeq 24
        21: .line 381
            aload 19 /* matcher */
            aload 12 /* lines */
            iload 14 /* lastFsStatLineNumber */
            iload 13 /* lineNumber */
            invokestatic com.android.server.BootReceiver.handleFsckFsStat:(Ljava/util/regex/Matcher;[Ljava/lang/String;II)V
        22: .line 382
            iload 13 /* lineNumber */
            istore 14 /* lastFsStatLineNumber */
        23: .line 383
            goto 25
        24: .line 384
      StackMap locals: java.util.regex.Matcher
      StackMap stack:
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "cannot parse fs_stat:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 15 /* line */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic android.util.Slog.w:(Ljava/lang/String;Ljava/lang/String;)I
            pop
        end local 19 // java.util.regex.Matcher matcher
        25: .line 387
      StackMap locals:
      StackMap stack:
            iinc 13 /* lineNumber */ 1
        end local 15 // java.lang.String line
        26: .line 375
            iinc 16 1
      StackMap locals: android.os.DropBoxManager java.util.HashMap java.lang.String int java.lang.String int int java.io.File long java.lang.String java.util.regex.Pattern java.lang.String[] int int top int int java.lang.String[]
      StackMap stack:
        27: iload 16
            iload 17
            if_icmplt 14
        28: .line 390
            iload 5 /* uploadEnabled */
            ifeq 30
            iload 6 /* uploadNeeded */
            ifeq 30
        29: .line 391
            aload 0 /* db */
            aload 1 /* timestamps */
            aload 2 /* headers */
            ldc "/dev/fscklogs/log"
            iload 3 /* maxSize */
            aload 4 /* tag */
            invokestatic com.android.server.BootReceiver.addFileToDropBox:(Landroid/os/DropBoxManager;Ljava/util/HashMap;Ljava/lang/String;Ljava/lang/String;ILjava/lang/String;)V
        30: .line 395
      StackMap locals: android.os.DropBoxManager java.util.HashMap java.lang.String int java.lang.String int int java.io.File long java.lang.String java.util.regex.Pattern java.lang.String[] int int
      StackMap stack:
            aload 7 /* file */
            invokevirtual java.io.File.delete:()Z
            pop
        31: .line 396
            return
        end local 14 // int lastFsStatLineNumber
        end local 13 // int lineNumber
        end local 12 // java.lang.String[] lines
        end local 11 // java.util.regex.Pattern pattern
        end local 10 // java.lang.String log
        end local 8 // long fileTime
        end local 7 // java.io.File file
        end local 6 // boolean uploadNeeded
        end local 5 // boolean uploadEnabled
        end local 4 // java.lang.String tag
        end local 3 // int maxSize
        end local 2 // java.lang.String headers
        end local 1 // java.util.HashMap timestamps
        end local 0 // android.os.DropBoxManager db
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   32     0                    db  Landroid/os/DropBoxManager;
            0   32     1            timestamps  Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Long;>;
            0   32     2               headers  Ljava/lang/String;
            0   32     3               maxSize  I
            0   32     4                   tag  Ljava/lang/String;
            1   32     5         uploadEnabled  Z
            4   32     6          uploadNeeded  Z
            6   32     7                  file  Ljava/io/File;
            7   32     8              fileTime  J
            9   32    10                   log  Ljava/lang/String;
           10   32    11               pattern  Ljava/util/regex/Pattern;
           11   32    12                 lines  [Ljava/lang/String;
           12   32    13            lineNumber  I
           13   32    14  lastFsStatLineNumber  I
           15   26    15                  line  Ljava/lang/String;
           20   25    19               matcher  Ljava/util/regex/Matcher;
    Exceptions:
      throws java.io.IOException
    Signature: (Landroid/os/DropBoxManager;Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Long;>;Ljava/lang/String;ILjava/lang/String;)V
    MethodParameters:
            Name  Flags
      db          
      timestamps  
      headers     
      maxSize     
      tag         

  private static void logFsMountTime();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=5, args_size=0
         0: .line 399
            getstatic com.android.server.BootReceiver.MOUNT_DURATION_PROPS_POSTFIX:[Ljava/lang/String;
            dup
            astore 3
            arraylength
            istore 2
            iconst_0
            istore 1
            goto 6
      StackMap locals: top int int java.lang.String[]
      StackMap stack:
         1: aload 3
            iload 1
            aaload
            astore 0 /* propPostfix */
        start local 0 // java.lang.String propPostfix
         2: .line 400
            new java.lang.StringBuilder
            dup
            ldc "ro.boottime.init.mount_all."
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* propPostfix */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            invokestatic android.os.SystemProperties.getInt:(Ljava/lang/String;I)I
            istore 4 /* duration */
        start local 4 // int duration
         3: .line 401
            iload 4 /* duration */
            ifeq 5
         4: .line 402
            aconst_null
            new java.lang.StringBuilder
            dup
            ldc "boot_mount_all_duration_"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* propPostfix */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iload 4 /* duration */
            invokestatic com.android.internal.logging.MetricsLogger.histogram:(Landroid/content/Context;Ljava/lang/String;I)V
        end local 4 // int duration
        end local 0 // java.lang.String propPostfix
         5: .line 399
      StackMap locals:
      StackMap stack:
            iinc 1 1
      StackMap locals:
      StackMap stack:
         6: iload 1
            iload 2
            if_icmplt 1
         7: .line 405
            return
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            2    5     0  propPostfix  Ljava/lang/String;
            3    5     4     duration  I

  private static void logSystemServerShutdownTimeMetrics();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=12, args_size=0
         0: .line 409
            new java.io.File
            dup
            ldc "/data/system/shutdown-metrics.txt"
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 0 /* metricsFile */
        start local 0 // java.io.File metricsFile
         1: .line 410
            aconst_null
            astore 1 /* metricsStr */
        start local 1 // java.lang.String metricsStr
         2: .line 411
            aload 0 /* metricsFile */
            invokevirtual java.io.File.exists:()Z
            ifeq 7
         3: .line 413
            aload 0 /* metricsFile */
            iconst_0
            aconst_null
            invokestatic android.os.FileUtils.readTextFile:(Ljava/io/File;ILjava/lang/String;)Ljava/lang/String;
            astore 1 /* metricsStr */
         4: .line 414
            goto 7
      StackMap locals: java.io.File java.lang.String
      StackMap stack: java.io.IOException
         5: astore 2 /* e */
        start local 2 // java.io.IOException e
         6: .line 415
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "Problem reading "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* metricsFile */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 2 /* e */
            invokestatic android.util.Slog.e:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
            pop
        end local 2 // java.io.IOException e
         7: .line 418
      StackMap locals:
      StackMap stack:
            aload 1 /* metricsStr */
            invokestatic android.text.TextUtils.isEmpty:(Ljava/lang/CharSequence;)Z
            ifne 34
         8: .line 419
            aconst_null
            astore 2 /* reboot */
        start local 2 // java.lang.String reboot
         9: .line 420
            aconst_null
            astore 3 /* reason */
        start local 3 // java.lang.String reason
        10: .line 421
            aconst_null
            astore 4 /* start_time */
        start local 4 // java.lang.String start_time
        11: .line 422
            aconst_null
            astore 5 /* duration */
        start local 5 // java.lang.String duration
        12: .line 423
            aload 1 /* metricsStr */
            ldc ","
            invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
            astore 6 /* array */
        start local 6 // java.lang.String[] array
        13: .line 424
            aload 6 /* array */
            dup
            astore 10
            arraylength
            istore 9
            iconst_0
            istore 8
            goto 32
      StackMap locals: java.io.File java.lang.String java.lang.String java.lang.String java.lang.String java.lang.String java.lang.String[] top int int java.lang.String[]
      StackMap stack:
        14: aload 10
            iload 8
            aaload
            astore 7 /* keyValueStr */
        start local 7 // java.lang.String keyValueStr
        15: .line 425
            aload 7 /* keyValueStr */
            ldc ":"
            invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
            astore 11 /* keyValue */
        start local 11 // java.lang.String[] keyValue
        16: .line 426
            aload 11 /* keyValue */
            arraylength
            iconst_2
            if_icmpeq 19
        17: .line 427
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "Wrong format of shutdown metrics - "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* metricsStr */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic android.util.Slog.e:(Ljava/lang/String;Ljava/lang/String;)I
            pop
        18: .line 428
            goto 31
        19: .line 431
      StackMap locals: java.io.File java.lang.String java.lang.String java.lang.String java.lang.String java.lang.String java.lang.String[] java.lang.String int int java.lang.String[] java.lang.String[]
      StackMap stack:
            aload 11 /* keyValue */
            iconst_0
            aaload
            ldc "shutdown_"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 23
        20: .line 432
            aload 11 /* keyValue */
            iconst_0
            aaload
            aload 11 /* keyValue */
            iconst_1
            aaload
            invokestatic com.android.server.BootReceiver.logTronShutdownMetric:(Ljava/lang/String;Ljava/lang/String;)V
        21: .line 433
            aload 11 /* keyValue */
            iconst_0
            aaload
            ldc "shutdown_system_server"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 23
        22: .line 434
            aload 11 /* keyValue */
            iconst_1
            aaload
            astore 5 /* duration */
        23: .line 437
      StackMap locals:
      StackMap stack:
            aload 11 /* keyValue */
            iconst_0
            aaload
            ldc "reboot"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 26
        24: .line 438
            aload 11 /* keyValue */
            iconst_1
            aaload
            astore 2 /* reboot */
        25: .line 439
            goto 31
      StackMap locals:
      StackMap stack:
        26: aload 11 /* keyValue */
            iconst_0
            aaload
            ldc "reason"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 29
        27: .line 440
            aload 11 /* keyValue */
            iconst_1
            aaload
            astore 3 /* reason */
        28: .line 441
            goto 31
      StackMap locals:
      StackMap stack:
        29: aload 11 /* keyValue */
            iconst_0
            aaload
            ldc "begin_shutdown"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 31
        30: .line 442
            aload 11 /* keyValue */
            iconst_1
            aaload
            astore 4 /* start_time */
        end local 11 // java.lang.String[] keyValue
        end local 7 // java.lang.String keyValueStr
        31: .line 424
      StackMap locals: java.io.File java.lang.String java.lang.String java.lang.String java.lang.String java.lang.String java.lang.String[] top int int java.lang.String[]
      StackMap stack:
            iinc 8 1
      StackMap locals:
      StackMap stack:
        32: iload 8
            iload 9
            if_icmplt 14
        33: .line 445
            aload 2 /* reboot */
            aload 3 /* reason */
            aload 4 /* start_time */
            aload 5 /* duration */
            invokestatic com.android.server.BootReceiver.logStatsdShutdownAtom:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
        end local 6 // java.lang.String[] array
        end local 5 // java.lang.String duration
        end local 4 // java.lang.String start_time
        end local 3 // java.lang.String reason
        end local 2 // java.lang.String reboot
        34: .line 447
      StackMap locals: java.io.File java.lang.String
      StackMap stack:
            aload 0 /* metricsFile */
            invokevirtual java.io.File.delete:()Z
            pop
        35: .line 448
            return
        end local 1 // java.lang.String metricsStr
        end local 0 // java.io.File metricsFile
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            1   36     0  metricsFile  Ljava/io/File;
            2   36     1   metricsStr  Ljava/lang/String;
            6    7     2            e  Ljava/io/IOException;
            9   34     2       reboot  Ljava/lang/String;
           10   34     3       reason  Ljava/lang/String;
           11   34     4   start_time  Ljava/lang/String;
           12   34     5     duration  Ljava/lang/String;
           13   34     6        array  [Ljava/lang/String;
           15   31     7  keyValueStr  Ljava/lang/String;
           16   31    11     keyValue  [Ljava/lang/String;
      Exception table:
        from    to  target  type
           3     4       5  Class java.io.IOException

  private static void logTronShutdownMetric(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // java.lang.String metricName
        start local 1 // java.lang.String valueStr
         0: .line 453
            aload 1 /* valueStr */
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            istore 2 /* value */
        start local 2 // int value
         1: .line 454
            goto 5
        end local 2 // int value
      StackMap locals:
      StackMap stack: java.lang.NumberFormatException
         2: pop
         3: .line 455
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "Cannot parse metric "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* metricName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " int value - "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* valueStr */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic android.util.Slog.e:(Ljava/lang/String;Ljava/lang/String;)I
            pop
         4: .line 456
            return
        start local 2 // int value
         5: .line 458
      StackMap locals: int
      StackMap stack:
            iload 2 /* value */
            iflt 7
         6: .line 459
            aconst_null
            aload 0 /* metricName */
            iload 2 /* value */
            invokestatic com.android.internal.logging.MetricsLogger.histogram:(Landroid/content/Context;Ljava/lang/String;I)V
         7: .line 461
      StackMap locals:
      StackMap stack:
            return
        end local 2 // int value
        end local 1 // java.lang.String valueStr
        end local 0 // java.lang.String metricName
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    8     0  metricName  Ljava/lang/String;
            0    8     1    valueStr  Ljava/lang/String;
            1    2     2       value  I
            5    8     2       value  I
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.NumberFormatException
    MethodParameters:
            Name  Flags
      metricName  
      valueStr    

  private static void logStatsdShutdownAtom(java.lang.String, java.lang.String, java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=4, args_size=4
         0: .line 506
            new java.lang.Error
            dup
            ldc "Unresolved compilation problem: \n\tSHUTDOWN_SEQUENCE_REPORTED cannot be resolved or is not a field\n"
            invokespecial java.lang.Error.<init>:(Ljava/lang/String;)V
            athrow
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    MethodParameters:
             Name  Flags
      rebootStr    
      reasonStr    
      startStr     
      durationStr  

  private static void logFsShutdownTime();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=6, args_size=0
         0: .line 510
            aconst_null
            astore 0 /* f */
        start local 0 // java.io.File f
         1: .line 511
            getstatic com.android.server.BootReceiver.LAST_KMSG_FILES:[Ljava/lang/String;
            dup
            astore 4
            arraylength
            istore 3
            iconst_0
            istore 2
            goto 8
      StackMap locals: java.io.File top int int java.lang.String[]
      StackMap stack:
         2: aload 4
            iload 2
            aaload
            astore 1 /* fileName */
        start local 1 // java.lang.String fileName
         3: .line 512
            new java.io.File
            dup
            aload 1 /* fileName */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 5 /* file */
        start local 5 // java.io.File file
         4: .line 513
            aload 5 /* file */
            invokevirtual java.io.File.exists:()Z
            ifne 5
            goto 7
         5: .line 514
      StackMap locals: java.io.File java.lang.String int int java.lang.String[] java.io.File
      StackMap stack:
            aload 5 /* file */
            astore 0 /* f */
         6: .line 515
            goto 9
        end local 5 // java.io.File file
        end local 1 // java.lang.String fileName
         7: .line 511
      StackMap locals: java.io.File top int int java.lang.String[]
      StackMap stack:
            iinc 2 1
      StackMap locals:
      StackMap stack:
         8: iload 2
            iload 3
            if_icmplt 2
         9: .line 517
      StackMap locals: java.io.File
      StackMap stack:
            aload 0 /* f */
            ifnonnull 11
        10: .line 518
            return
        11: .line 525
      StackMap locals:
      StackMap stack:
            aload 0 /* f */
            sipush -16384
            aconst_null
            invokestatic android.os.FileUtils.readTextFile:(Ljava/io/File;ILjava/lang/String;)Ljava/lang/String;
            astore 1 /* lines */
        start local 1 // java.lang.String lines
        12: .line 526
            goto 16
        end local 1 // java.lang.String lines
      StackMap locals:
      StackMap stack: java.io.IOException
        13: astore 2 /* e */
        start local 2 // java.io.IOException e
        14: .line 527
            ldc "BootReceiver"
            ldc "cannot read last msg"
            aload 2 /* e */
            invokestatic android.util.Slog.w:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
            pop
        15: .line 528
            return
        end local 2 // java.io.IOException e
        start local 1 // java.lang.String lines
        16: .line 530
      StackMap locals: java.lang.String
      StackMap stack:
            ldc "powerctl_shutdown_time_ms:([0-9]+):([0-9]+)"
            bipush 8
            invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;I)Ljava/util/regex/Pattern;
            astore 2 /* pattern */
        start local 2 // java.util.regex.Pattern pattern
        17: .line 531
            aload 2 /* pattern */
            aload 1 /* lines */
            invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
            astore 3 /* matcher */
        start local 3 // java.util.regex.Matcher matcher
        18: .line 532
            aload 3 /* matcher */
            invokevirtual java.util.regex.Matcher.find:()Z
            ifeq 27
        19: .line 533
            aconst_null
            ldc "boot_fs_shutdown_duration"
        20: .line 534
            aload 3 /* matcher */
            iconst_1
            invokevirtual java.util.regex.Matcher.group:(I)Ljava/lang/String;
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
        21: .line 533
            invokestatic com.android.internal.logging.MetricsLogger.histogram:(Landroid/content/Context;Ljava/lang/String;I)V
        22: .line 535
            aconst_null
            ldc "boot_fs_shutdown_umount_stat"
        23: .line 536
            aload 3 /* matcher */
            iconst_2
            invokevirtual java.util.regex.Matcher.group:(I)Ljava/lang/String;
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
        24: .line 535
            invokestatic com.android.internal.logging.MetricsLogger.histogram:(Landroid/content/Context;Ljava/lang/String;I)V
        25: .line 537
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "boot_fs_shutdown,"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* matcher */
            iconst_1
            invokevirtual java.util.regex.Matcher.group:(I)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ","
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* matcher */
            iconst_2
            invokevirtual java.util.regex.Matcher.group:(I)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic android.util.Slog.i:(Ljava/lang/String;Ljava/lang/String;)I
            pop
        26: .line 538
            goto 31
        27: .line 542
      StackMap locals: java.util.regex.Pattern java.util.regex.Matcher
      StackMap stack:
            aconst_null
            ldc "boot_fs_shutdown_umount_stat"
        28: .line 543
            iconst_4
        29: .line 542
            invokestatic com.android.internal.logging.MetricsLogger.histogram:(Landroid/content/Context;Ljava/lang/String;I)V
        30: .line 544
            ldc "BootReceiver"
            ldc "boot_fs_shutdown, string not found"
            invokestatic android.util.Slog.w:(Ljava/lang/String;Ljava/lang/String;)I
            pop
        31: .line 546
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.util.regex.Matcher matcher
        end local 2 // java.util.regex.Pattern pattern
        end local 1 // java.lang.String lines
        end local 0 // java.io.File f
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            1   32     0         f  Ljava/io/File;
            3    7     1  fileName  Ljava/lang/String;
            4    7     5      file  Ljava/io/File;
           12   13     1     lines  Ljava/lang/String;
           16   32     1     lines  Ljava/lang/String;
           14   16     2         e  Ljava/io/IOException;
           17   32     2   pattern  Ljava/util/regex/Pattern;
           18   32     3   matcher  Ljava/util/regex/Matcher;
      Exception table:
        from    to  target  type
          11    12      13  Class java.io.IOException

  public static int fixFsckFsStat(java.lang.String, int, java.lang.String[], int, int);
    descriptor: (Ljava/lang/String;I[Ljava/lang/String;II)I
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=17, args_size=5
        start local 0 // java.lang.String partition
        start local 1 // int statOrg
        start local 2 // java.lang.String[] lines
        start local 3 // int startLineNumber
        start local 4 // int endLineNumber
         0: .line 563
            iload 1 /* statOrg */
            istore 5 /* stat */
        start local 5 // int stat
         1: .line 564
            iload 5 /* stat */
            sipush 1024
            iand
            ifeq 70
         2: .line 567
            ldc "Pass ([1-9]E?):"
            invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
            astore 6 /* passPattern */
        start local 6 // java.util.regex.Pattern passPattern
         3: .line 568
            ldc "Inode [0-9]+ extent tree.*could be shorter"
            invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
            astore 7 /* treeOptPattern */
        start local 7 // java.util.regex.Pattern treeOptPattern
         4: .line 569
            ldc ""
            astore 8 /* currentPass */
        start local 8 // java.lang.String currentPass
         5: .line 570
            iconst_0
            istore 9 /* foundTreeOptimization */
        start local 9 // boolean foundTreeOptimization
         6: .line 571
            iconst_0
            istore 10 /* foundQuotaFix */
        start local 10 // boolean foundQuotaFix
         7: .line 572
            iconst_0
            istore 11 /* foundTimestampAdjustment */
        start local 11 // boolean foundTimestampAdjustment
         8: .line 573
            iconst_0
            istore 12 /* foundOtherFix */
        start local 12 // boolean foundOtherFix
         9: .line 574
            aconst_null
            astore 13 /* otherFixLine */
        start local 13 // java.lang.String otherFixLine
        10: .line 575
            iload 3 /* startLineNumber */
            istore 14 /* i */
        start local 14 // int i
        11: goto 56
        12: .line 576
      StackMap locals: java.lang.String int java.lang.String[] int int int java.util.regex.Pattern java.util.regex.Pattern java.lang.String int int int int java.lang.String int
      StackMap stack:
            aload 2 /* lines */
            iload 14 /* i */
            aaload
            astore 15 /* line */
        start local 15 // java.lang.String line
        13: .line 577
            aload 15 /* line */
            ldc "FILE SYSTEM WAS MODIFIED"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 15
        14: .line 578
            goto 57
        15: .line 579
      StackMap locals: java.lang.String
      StackMap stack:
            aload 15 /* line */
            ldc "Pass "
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 20
        16: .line 580
            aload 6 /* passPattern */
            aload 15 /* line */
            invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
            astore 16 /* matcher */
        start local 16 // java.util.regex.Matcher matcher
        17: .line 581
            aload 16 /* matcher */
            invokevirtual java.util.regex.Matcher.find:()Z
            ifeq 55
        18: .line 582
            aload 16 /* matcher */
            iconst_1
            invokevirtual java.util.regex.Matcher.group:(I)Ljava/lang/String;
            astore 8 /* currentPass */
        end local 16 // java.util.regex.Matcher matcher
        19: .line 584
            goto 55
      StackMap locals:
      StackMap stack:
        20: aload 15 /* line */
            ldc "Inode "
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 31
        21: .line 585
            aload 7 /* treeOptPattern */
            aload 15 /* line */
            invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
            astore 16 /* matcher */
        start local 16 // java.util.regex.Matcher matcher
        22: .line 586
            aload 16 /* matcher */
            invokevirtual java.util.regex.Matcher.find:()Z
            ifeq 28
            aload 8 /* currentPass */
            ldc "1"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 28
        23: .line 587
            iconst_1
            istore 9 /* foundTreeOptimization */
        24: .line 588
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "fs_stat, partition:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* partition */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " found tree optimization:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        25: .line 589
            aload 15 /* line */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        26: .line 588
            invokestatic android.util.Slog.i:(Ljava/lang/String;Ljava/lang/String;)I
            pop
        27: .line 590
            goto 55
        28: .line 591
      StackMap locals: java.util.regex.Matcher
      StackMap stack:
            iconst_1
            istore 12 /* foundOtherFix */
        29: .line 592
            aload 15 /* line */
            astore 13 /* otherFixLine */
        30: .line 593
            goto 57
        end local 16 // java.util.regex.Matcher matcher
        31: .line 595
      StackMap locals:
      StackMap stack:
            aload 15 /* line */
            ldc "[QUOTA WARNING]"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 39
            aload 8 /* currentPass */
            ldc "5"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 39
        32: .line 596
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "fs_stat, partition:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* partition */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " found quota warning:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        33: .line 597
            aload 15 /* line */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        34: .line 596
            invokestatic android.util.Slog.i:(Ljava/lang/String;Ljava/lang/String;)I
            pop
        35: .line 598
            iconst_1
            istore 10 /* foundQuotaFix */
        36: .line 599
            iload 9 /* foundTreeOptimization */
            ifne 55
        37: .line 600
            aload 15 /* line */
            astore 13 /* otherFixLine */
        38: .line 601
            goto 57
        39: .line 603
      StackMap locals:
      StackMap stack:
            aload 15 /* line */
            ldc "Update quota info"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 40
            aload 8 /* currentPass */
            ldc "5"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 55
        40: .line 605
      StackMap locals:
      StackMap stack:
            aload 15 /* line */
            ldc "Timestamp(s) on inode"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 50
        41: .line 606
            aload 15 /* line */
            ldc "beyond 2310-04-04 are likely pre-1970"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 50
        42: .line 607
            aload 8 /* currentPass */
            ldc "1"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 50
        43: .line 608
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "fs_stat, partition:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* partition */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " found timestamp adjustment:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        44: .line 609
            aload 15 /* line */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        45: .line 608
            invokestatic android.util.Slog.i:(Ljava/lang/String;Ljava/lang/String;)I
            pop
        46: .line 611
            aload 2 /* lines */
            iload 14 /* i */
            iconst_1
            iadd
            aaload
            ldc "Fix? yes"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 48
        47: .line 612
            iinc 14 /* i */ 1
        48: .line 614
      StackMap locals:
      StackMap stack:
            iconst_1
            istore 11 /* foundTimestampAdjustment */
        49: .line 615
            goto 55
        50: .line 616
      StackMap locals:
      StackMap stack:
            aload 15 /* line */
            invokevirtual java.lang.String.trim:()Ljava/lang/String;
            astore 15 /* line */
        51: .line 618
            aload 15 /* line */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 55
            aload 8 /* currentPass */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 55
        52: .line 619
            iconst_1
            istore 12 /* foundOtherFix */
        53: .line 620
            aload 15 /* line */
            astore 13 /* otherFixLine */
        54: .line 621
            goto 57
        end local 15 // java.lang.String line
        55: .line 575
      StackMap locals:
      StackMap stack:
            iinc 14 /* i */ 1
      StackMap locals:
      StackMap stack:
        56: iload 14 /* i */
            iload 4 /* endLineNumber */
            if_icmplt 12
        end local 14 // int i
        57: .line 625
      StackMap locals:
      StackMap stack:
            iload 12 /* foundOtherFix */
            ifeq 61
        58: .line 626
            aload 13 /* otherFixLine */
            ifnull 70
        59: .line 627
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "fs_stat, partition:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* partition */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " fix:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 13 /* otherFixLine */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic android.util.Slog.i:(Ljava/lang/String;Ljava/lang/String;)I
            pop
        60: .line 629
            goto 70
      StackMap locals:
      StackMap stack:
        61: iload 10 /* foundQuotaFix */
            ifeq 66
            iload 9 /* foundTreeOptimization */
            ifne 66
        62: .line 630
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "fs_stat, got quota fix without tree optimization, partition:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        63: .line 631
            aload 0 /* partition */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        64: .line 630
            invokestatic android.util.Slog.i:(Ljava/lang/String;Ljava/lang/String;)I
            pop
        65: .line 632
            goto 70
      StackMap locals:
      StackMap stack:
        66: iload 9 /* foundTreeOptimization */
            ifeq 67
            iload 10 /* foundQuotaFix */
            ifne 68
      StackMap locals:
      StackMap stack:
        67: iload 11 /* foundTimestampAdjustment */
            ifeq 70
        68: .line 634
      StackMap locals:
      StackMap stack:
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "fs_stat, partition:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* partition */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " fix ignored"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic android.util.Slog.i:(Ljava/lang/String;Ljava/lang/String;)I
            pop
        69: .line 635
            iload 5 /* stat */
            sipush -1025
            iand
            istore 5 /* stat */
        end local 13 // java.lang.String otherFixLine
        end local 12 // boolean foundOtherFix
        end local 11 // boolean foundTimestampAdjustment
        end local 10 // boolean foundQuotaFix
        end local 9 // boolean foundTreeOptimization
        end local 8 // java.lang.String currentPass
        end local 7 // java.util.regex.Pattern treeOptPattern
        end local 6 // java.util.regex.Pattern passPattern
        70: .line 638
      StackMap locals: java.lang.String int java.lang.String[] int int int
      StackMap stack:
            iload 5 /* stat */
            ireturn
        end local 5 // int stat
        end local 4 // int endLineNumber
        end local 3 // int startLineNumber
        end local 2 // java.lang.String[] lines
        end local 1 // int statOrg
        end local 0 // java.lang.String partition
      LocalVariableTable:
        Start  End  Slot                      Name  Signature
            0   71     0                 partition  Ljava/lang/String;
            0   71     1                   statOrg  I
            0   71     2                     lines  [Ljava/lang/String;
            0   71     3           startLineNumber  I
            0   71     4             endLineNumber  I
            1   71     5                      stat  I
            3   70     6               passPattern  Ljava/util/regex/Pattern;
            4   70     7            treeOptPattern  Ljava/util/regex/Pattern;
            5   70     8               currentPass  Ljava/lang/String;
            6   70     9     foundTreeOptimization  Z
            7   70    10             foundQuotaFix  Z
            8   70    11  foundTimestampAdjustment  Z
            9   70    12             foundOtherFix  Z
           10   70    13              otherFixLine  Ljava/lang/String;
           11   57    14                         i  I
           13   55    15                      line  Ljava/lang/String;
           17   19    16                   matcher  Ljava/util/regex/Matcher;
           22   31    16                   matcher  Ljava/util/regex/Matcher;
    RuntimeInvisibleAnnotations: 
      com.android.internal.annotations.VisibleForTesting()
    RuntimeInvisibleTypeAnnotations: 
      METHOD_RETURN
        com.android.internal.annotations.VisibleForTesting()
    MethodParameters:
                 Name  Flags
      partition        
      statOrg          
      lines            
      startLineNumber  
      endLineNumber    

  private static void handleFsckFsStat(java.util.regex.Matcher, java.lang.String[], int, int);
    descriptor: (Ljava/util/regex/Matcher;[Ljava/lang/String;II)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=6, args_size=4
        start local 0 // java.util.regex.Matcher match
        start local 1 // java.lang.String[] lines
        start local 2 // int startLineNumber
        start local 3 // int endLineNumber
         0: .line 643
            aload 0 /* match */
            iconst_1
            invokevirtual java.util.regex.Matcher.group:(I)Ljava/lang/String;
            astore 4 /* partition */
        start local 4 // java.lang.String partition
         1: .line 646
            aload 0 /* match */
            iconst_2
            invokevirtual java.util.regex.Matcher.group:(I)Ljava/lang/String;
            invokestatic java.lang.Integer.decode:(Ljava/lang/String;)Ljava/lang/Integer;
            invokevirtual java.lang.Integer.intValue:()I
            istore 5 /* stat */
        start local 5 // int stat
         2: .line 647
            goto 6
        end local 5 // int stat
      StackMap locals: java.util.regex.Matcher java.lang.String[] int int java.lang.String
      StackMap stack: java.lang.NumberFormatException
         3: pop
         4: .line 648
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "cannot parse fs_stat: partition:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* partition */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " stat:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* match */
            iconst_2
            invokevirtual java.util.regex.Matcher.group:(I)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic android.util.Slog.w:(Ljava/lang/String;Ljava/lang/String;)I
            pop
         5: .line 649
            return
        start local 5 // int stat
         6: .line 651
      StackMap locals: int
      StackMap stack:
            aload 4 /* partition */
            iload 5 /* stat */
            aload 1 /* lines */
            iload 2 /* startLineNumber */
            iload 3 /* endLineNumber */
            invokestatic com.android.server.BootReceiver.fixFsckFsStat:(Ljava/lang/String;I[Ljava/lang/String;II)I
            istore 5 /* stat */
         7: .line 652
            aconst_null
            new java.lang.StringBuilder
            dup
            ldc "boot_fs_stat_"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* partition */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iload 5 /* stat */
            invokestatic com.android.internal.logging.MetricsLogger.histogram:(Landroid/content/Context;Ljava/lang/String;I)V
         8: .line 653
            ldc "BootReceiver"
            new java.lang.StringBuilder
            dup
            ldc "fs_stat, partition:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* partition */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " stat:0x"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 5 /* stat */
            invokestatic java.lang.Integer.toHexString:(I)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic android.util.Slog.i:(Ljava/lang/String;Ljava/lang/String;)I
            pop
         9: .line 654
            return
        end local 5 // int stat
        end local 4 // java.lang.String partition
        end local 3 // int endLineNumber
        end local 2 // int startLineNumber
        end local 1 // java.lang.String[] lines
        end local 0 // java.util.regex.Matcher match
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   10     0            match  Ljava/util/regex/Matcher;
            0   10     1            lines  [Ljava/lang/String;
            0   10     2  startLineNumber  I
            0   10     3    endLineNumber  I
            1   10     4        partition  Ljava/lang/String;
            2    3     5             stat  I
            6   10     5             stat  I
      Exception table:
        from    to  target  type
           1     2       3  Class java.lang.NumberFormatException
    MethodParameters:
                 Name  Flags
      match            
      lines            
      startLineNumber  
      endLineNumber    

  private static java.util.HashMap<java.lang.String, java.lang.Long> readTimestamps();
    descriptor: ()Ljava/util/HashMap;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 661
            new java.lang.Error
            dup
            ldc "Unresolved compilation problems: \n\tXmlPullParser cannot be resolved to a type\n\tThe method newPullParser() from the type Xml refers to the missing type XmlPullParser\n\tXmlPullParser cannot be resolved to a variable\n\tXmlPullParser cannot be resolved to a variable\n\tXmlPullParser cannot be resolved to a variable\n\tXmlPullParser cannot be resolved to a variable\n\tXmlPullParser cannot be resolved to a variable\n\tXmlPullParser cannot be resolved to a variable\n\tXmlPullParser cannot be resolved to a variable\n\tXmlPullParserException cannot be resolved to a type\n"
            invokespecial java.lang.Error.<init>:(Ljava/lang/String;)V
            athrow
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Signature: ()Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Long;>;

  private void writeTimestamps(java.util.HashMap<java.lang.String, java.lang.Long>);
    descriptor: (Ljava/util/HashMap;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.android.server.BootReceiver this
         0: .line 724
            new java.lang.Error
            dup
            ldc "Unresolved compilation problem: \n\tXmlSerializer cannot be resolved to a type\n"
            invokespecial java.lang.Error.<init>:(Ljava/lang/String;)V
            athrow
        end local 0 // com.android.server.BootReceiver this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/android/server/BootReceiver;
    Signature: (Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Long;>;)V
    MethodParameters:
            Name  Flags
      timestamps  
}
SourceFile: "BootReceiver.java"
NestMembers:
  com.android.server.BootReceiver$1  com.android.server.BootReceiver$2
InnerClasses:
  com.android.server.BootReceiver$1
  com.android.server.BootReceiver$2