From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Message-Id: <20110729124000.481435260@linux.vnet.ibm.com> Date: Fri, 29 Jul 2011 14:39:45 +0200 From: Michael Holzheu Subject: [patch 1/3] kdump: Add new machine_kexec_finish() architecture callback References: <20110729123944.562622201@linux.vnet.ibm.com> Content-Disposition: inline; filename=s390-kdump-common-kexec_finish.patch Sender: linux-kernel-owner@vger.kernel.org List-Archive: List-Post: To: vgoyal@redhat.com Cc: ebiederm@xmission.com, mahesh@linux.vnet.ibm.com, hbabu@us.ibm.com, oomichi@mxs.nes.nec.co.jp, horms@verge.net.au, schwidefsky@de.ibm.com, heiko.carstens@de.ibm.com, kexec@lists.infradead.org, linux-kernel@vger.kernel.org, linux-s390@vger.kernel.org List-ID: From: Michael Holzheu In order to be able to set the "kdump active" flag on s390, this patch adds the new kexec architecture callback "machine_kexec_finish()". Signed-off-by: Michael Holzheu --- include/linux/kexec.h | 1 + kernel/kexec.c | 8 ++++++++ 2 files changed, 9 insertions(+) --- a/include/linux/kexec.h +++ b/include/linux/kexec.h @@ -115,6 +115,7 @@ struct kimage { /* kexec interface functions */ extern void machine_kexec(struct kimage *image); extern int machine_kexec_prepare(struct kimage *image); +extern void machine_kexec_finish(struct kimage *image, int flags); extern void machine_kexec_cleanup(struct kimage *image); extern asmlinkage long sys_kexec_load(unsigned long entry, unsigned long nr_segments, --- a/kernel/kexec.c +++ b/kernel/kexec.c @@ -1017,6 +1017,7 @@ SYSCALL_DEFINE4(kexec_load, unsigned lon kimage_terminate(image); } /* Install the new kernel, and Uninstall the old */ + machine_kexec_finish(image, flags); image = xchg(dest_image, image); out: @@ -1026,6 +1027,13 @@ out: return result; } +/* + * provide an empty default implementation here -- architecture + * code may override this + */ +void __weak machine_kexec_finish(struct kimage *image, int flags) +{} + #ifdef CONFIG_COMPAT asmlinkage long compat_sys_kexec_load(unsigned long entry, unsigned long nr_segments,