dumpstate: Add support for apanic crash data

Signed-off-by: San Mehat <san@google.com>
diff --git a/cmds/dumpstate/dumpstate.c b/cmds/dumpstate/dumpstate.c
index 18713e9..3ddc922 100644
--- a/cmds/dumpstate/dumpstate.c
+++ b/cmds/dumpstate/dumpstate.c
@@ -20,6 +20,7 @@
 #include <unistd.h>
 #include <sys/stat.h>
 #include <limits.h>
+#include <errno.h>
 #include <fcntl.h>
 #include <sys/time.h>
 #include <sys/resource.h>
@@ -34,6 +35,8 @@
 
 static struct tm now;
 
+static void dump_kernel_log(const char *path, const char *title) ;
+
 /* dumps the current system state to stdout */
 static void dumpstate(int full) {
     if (full) {
@@ -101,8 +104,12 @@
         DUMP("/data/system/packages.xml");
         PRINT("------ PACKAGE UID ERRORS ------");
         DUMP("/data/system/uiderrors.txt");
-        PRINT("------ LAST KERNEL LOG ------");
-        DUMP("/data/last_kmsg");
+
+        dump_kernel_log("/data/dontpanic/last_kmsg", "RAMCONSOLE");
+        dump_kernel_log("/data/dontpanic/apanic_console",
+                        "PANIC CONSOLE");
+        dump_kernel_log("/data/dontpanic/apanic_threads",
+                        "PANIC THREADS");
     }
     PRINT("========================================================");
     PRINT("== build.prop");
@@ -295,3 +302,13 @@
     return 0;
 }
 
+static void dump_kernel_log(const char *path, const char *title) 
+
+{
+	printf("------ KERNEL %s LOG ------\n", title);
+        if (access(path, R_OK) < 0)
+		printf("%s: %s\n", path, strerror(errno));
+	else
+        	DUMP(path);
+}
+