+ add-a-sysfs-file-to-determine-if-a-kexec-kernel-is-loaded.patch added to -mm tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



The patch titled

     Add a sysfs file to determine if a kexec kernel is loaded

has been added to the -mm tree.  Its filename is

     add-a-sysfs-file-to-determine-if-a-kexec-kernel-is-loaded.patch

See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find
out what to do about this

------------------------------------------------------
Subject: Add a sysfs file to determine if a kexec kernel is loaded
From: Jeff Moyer <jmoyer@xxxxxxxxxx>


Create two files in /sys/kernel, kexec_loaded and kexec_crash_loaded.  Each
file contains a simple boolean value indicating whether the relevant kernel
has been loaded into memory.  The motivation for this is geared around
support.

Signed-off-by: Jeff Moyer <jmoyer@xxxxxxxxxx>
Cc: "Eric W. Biederman" <ebiederm@xxxxxxxxxxxx>
Signed-off-by: Andrew Morton <akpm@xxxxxxxx>
---

 include/linux/kexec.h |    1 +
 kernel/kexec.c        |    2 +-
 kernel/ksysfs.c       |   19 +++++++++++++++++++
 3 files changed, 21 insertions(+), 1 deletion(-)

diff -puN include/linux/kexec.h~add-a-sysfs-file-to-determine-if-a-kexec-kernel-is-loaded include/linux/kexec.h
--- 25/include/linux/kexec.h~add-a-sysfs-file-to-determine-if-a-kexec-kernel-is-loaded	Fri May 19 14:22:40 2006
+++ 25-akpm/include/linux/kexec.h	Fri May 19 14:22:40 2006
@@ -106,6 +106,7 @@ extern struct page *kimage_alloc_control
 extern void crash_kexec(struct pt_regs *);
 int kexec_should_crash(struct task_struct *);
 extern struct kimage *kexec_image;
+extern struct kimage *kexec_crash_image;
 
 #define KEXEC_ON_CRASH  0x00000001
 #define KEXEC_ARCH_MASK 0xffff0000
diff -puN kernel/kexec.c~add-a-sysfs-file-to-determine-if-a-kexec-kernel-is-loaded kernel/kexec.c
--- 25/kernel/kexec.c~add-a-sysfs-file-to-determine-if-a-kexec-kernel-is-loaded	Fri May 19 14:22:40 2006
+++ 25-akpm/kernel/kexec.c	Fri May 19 14:25:06 2006
@@ -903,7 +903,7 @@ static int kimage_load_segment(struct ki
  * that to happen you need to do that yourself.
  */
 struct kimage *kexec_image = NULL;
-static struct kimage *kexec_crash_image = NULL;
+struct kimage *kexec_crash_image = NULL;
 /*
  * A home grown binary mutex.
  * Nothing can wait so this mutex is safe to use
diff -puN kernel/ksysfs.c~add-a-sysfs-file-to-determine-if-a-kexec-kernel-is-loaded kernel/ksysfs.c
--- 25/kernel/ksysfs.c~add-a-sysfs-file-to-determine-if-a-kexec-kernel-is-loaded	Fri May 19 14:22:40 2006
+++ 25-akpm/kernel/ksysfs.c	Fri May 19 14:22:40 2006
@@ -14,6 +14,7 @@
 #include <linux/sysfs.h>
 #include <linux/module.h>
 #include <linux/init.h>
+#include <linux/kexec.h>
 
 #define KERNEL_ATTR_RO(_name) \
 static struct subsys_attribute _name##_attr = __ATTR_RO(_name)
@@ -48,6 +49,20 @@ static ssize_t uevent_helper_store(struc
 KERNEL_ATTR_RW(uevent_helper);
 #endif
 
+#ifdef CONFIG_KEXEC
+static ssize_t kexec_loaded_show(struct subsystem *subsys, char *page)
+{
+	return sprintf(page, "%d\n", !!kexec_image);
+}
+KERNEL_ATTR_RO(kexec_loaded);
+
+static ssize_t kexec_crash_loaded_show(struct subsystem *subsys, char *page)
+{
+	return sprintf(page, "%d\n", !!kexec_crash_image);
+}
+KERNEL_ATTR_RO(kexec_crash_loaded);
+#endif /* CONFIG_KEXEC */
+
 decl_subsys(kernel, NULL, NULL);
 EXPORT_SYMBOL_GPL(kernel_subsys);
 
@@ -56,6 +71,10 @@ static struct attribute * kernel_attrs[]
 	&uevent_seqnum_attr.attr,
 	&uevent_helper_attr.attr,
 #endif
+#ifdef CONFIG_KEXEC
+	&kexec_loaded_attr.attr,
+	&kexec_crash_loaded_attr.attr,
+#endif
 	NULL
 };
 
_

Patches currently in -mm which might be from jmoyer@xxxxxxxxxx are

add-a-sysfs-file-to-determine-if-a-kexec-kernel-is-loaded.patch
add-a-sysfs-file-to-determine-if-a-kexec-kernel-is-loaded-tidy.patch

-
To unsubscribe from this list: send the line "unsubscribe mm-commits" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Kernel Newbies FAQ]     [Kernel Archive]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [Bugtraq]     [Photo]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]

  Powered by Linux