s3: Log the correct core path on Linux if core_pattern is set
authorVolker Lendecke <vl@samba.org>
Fri, 23 Jul 2010 10:22:23 +0000 (12:22 +0200)
committerVolker Lendecke <vl@samba.org>
Mon, 26 Jul 2010 13:50:06 +0000 (15:50 +0200)
Contributions from Bill Hymas, IBM

source3/configure.in
source3/lib/fault.c

index f7c06770544e569c282091847bb8afe5f5bb451f..fa5d13894108471eded6e68b6e0a6bd2897d3032 100644 (file)
@@ -1085,6 +1085,15 @@ AC_CHECK_LIB(exc, trace_back_stack)
 # check for sysctlbyname for BSD systems
 AC_CHECK_FUNCS(sysctlbyname)
 
+#################################################
+# Check to see if core dump directory is defined in linux
+# with /proc/sys/kernel/core_pattern
+
+AC_CHECK_FILE([/proc/sys/kernel/core_pattern],
+       AC_DEFINE(HAVE_SYS_KERNEL_PROC_CORE_PATTERN, 1,
+       [Whether Linux kernel uses core_pattern for core files]),
+        [])
+
 #############################
 # check if building with gpfs
 AC_CHECK_HEADERS(gpfs_gpl.h)
index bf61bb26c43ca8fa7e0bf3b4ba12b6c41872d8a6..6430c8e2923ba7a8cd76c0454e53c3d358a11956 100644 (file)
@@ -192,6 +192,52 @@ static char *get_freebsd_corepath(void)
 }
 #endif
 
+#if defined(HAVE_SYS_KERNEL_PROC_CORE_PATTERN)
+
+/**
+ * Get the Linux corepath.
+ *
+ * On Linux the contents of /proc/sys/kernel/core_pattern indicates the
+ * location of the core path.
+ */
+static char *get_linux_corepath(void)
+{
+       char *end;
+       int fd;
+       char *result;
+
+       fd = open("/proc/sys/kernel/core_pattern", O_RDONLY, 0);
+       if (fd == -1) {
+               return NULL;
+       }
+
+       result = afdgets(fd, NULL, 0);
+       close(fd);
+
+       if (result == NULL) {
+               return NULL;
+       }
+
+       if (result[0] != '/') {
+               /*
+                * No absolute path, use the default (cwd)
+                */
+               TALLOC_FREE(result);
+               return NULL;
+       }
+       /* Strip off the common filename expansion */
+
+       end = strrchr_m(result, '/');
+
+       if ((end != result) /* this would be the only / */
+           && (end != NULL)) {
+               *end = '\0';
+       }
+       return result;
+}
+#endif
+
+
 /**
  * Try getting system-specific corepath if one exists.
  *
@@ -200,11 +246,18 @@ static char *get_freebsd_corepath(void)
 static char *get_corepath(const char *logbase, const char *progname)
 {
 #if (defined(FREEBSD) && defined(HAVE_SYSCTLBYNAME))
+       char *tmp_corepath = NULL;
+       tmp_corepath = get_freebsd_corepath();
 
-       /* @todo: Add support for the linux corepath. */
+       /* If this has been set correctly, we're done. */
+       if (tmp_corepath) {
+               return tmp_corepath;
+       }
+#endif
 
+#if defined(HAVE_SYS_KERNEL_PROC_CORE_PATTERN)
        char *tmp_corepath = NULL;
-       tmp_corepath = get_freebsd_corepath();
+       tmp_corepath = get_linux_corepath();
 
        /* If this has been set correctly, we're done. */
        if (tmp_corepath) {