From 0730d377b6a6f6cdac25f26016a95db8a9333802 Mon Sep 17 00:00:00 2001
Message-Id: <0730d377b6a6f6cdac25f26016a95db8a9333802.1431592766.git.panand@redhat.com>
In-Reply-To: <1fb6841aa15407dbf371589d7abca7bc2d35815c.1431592766.git.panand@redhat.com>
References: <1fb6841aa15407dbf371589d7abca7bc2d35815c.1431592766.git.panand@redhat.com>
From: Pratyush Anand <panand@redhat.com>
Date: Fri, 17 Apr 2015 10:54:55 -0700
Subject: [PATCH 03/17] arm64: Add support for --reuse-cmdline option
Signed-off-by: Pratyush Anand <panand@redhat.com>
Signed-off-by: Geoff Levand <geoff@infradead.org>
---
kexec/arch/arm64/include/arch/options.h | 7 +++++--
kexec/arch/arm64/kexec-arm64.c | 8 +++++++-
2 files changed, 12 insertions(+), 3 deletions(-)
diff --git a/kexec/arch/arm64/include/arch/options.h b/kexec/arch/arm64/include/arch/options.h
index 51afc5f1f6f2..903b4a1fbd7f 100644
--- a/kexec/arch/arm64/include/arch/options.h
+++ b/kexec/arch/arm64/include/arch/options.h
@@ -6,7 +6,8 @@
#define OPT_INITRD ((OPT_MAX)+2)
#define OPT_LITE ((OPT_MAX)+3)
#define OPT_PORT ((OPT_MAX)+4)
-#define OPT_ARCH_MAX ((OPT_MAX)+5)
+#define OPT_REUSE_CMDLINE ((OPT_MAX+5))
+#define OPT_ARCH_MAX ((OPT_MAX)+6)
#define KEXEC_ARCH_OPTIONS \
KEXEC_OPTIONS \
@@ -17,6 +18,7 @@
{ "lite", 0, NULL, OPT_LITE }, \
{ "port", 1, NULL, OPT_PORT }, \
{ "ramdisk", 1, NULL, OPT_INITRD }, \
+ { "reuse-cmdline", 0, NULL, OPT_REUSE_CMDLINE }, \
#define KEXEC_ARCH_OPT_STR KEXEC_OPT_STR /* Only accept long arch options. */
#define KEXEC_ALL_OPTIONS KEXEC_ARCH_OPTIONS
@@ -29,7 +31,8 @@ static const char arm64_opts_usage[] __attribute__ ((unused)) =
" --initrd=FILE Use FILE as the kernel initial ramdisk.\n"
" --lite Fast reboot, no memory integrity checks - currently NOT SUPPORTED.\n");
" --port=ADDRESS Purgatory output to port ADDRESS.\n"
-" --ramdisk=FILE Use FILE as the kernel initial ramdisk.\n";
+" --ramdisk=FILE Use FILE as the kernel initial ramdisk.\n"
+" --reuse-cmdline Use command line arg of primary kernel.\n";
struct arm64_opts {
const char *command_line;
diff --git a/kexec/arch/arm64/kexec-arm64.c b/kexec/arch/arm64/kexec-arm64.c
index 0860810b6e86..22d70244f8db 100644
--- a/kexec/arch/arm64/kexec-arm64.c
+++ b/kexec/arch/arm64/kexec-arm64.c
@@ -75,13 +75,18 @@ int arch_process_options(int argc, char **argv)
{ 0 }
};
int opt;
+ const char *append = NULL;
+ char *tmp_cmdline = NULL;
for (opt = 0; opt != -1; ) {
opt = getopt_long(argc, argv, short_options, options, 0);
switch (opt) {
case OPT_APPEND:
- arm64_opts.command_line = optarg;
+ append = optarg;
+ break;
+ case OPT_REUSE_CMDLINE:
+ tmp_cmdline = get_command_line();
break;
case OPT_DTB:
arm64_opts.dtb = optarg;
@@ -101,6 +106,7 @@ int arch_process_options(int argc, char **argv)
}
}
+ arm64_opts.command_line = concat_cmdline(tmp_cmdline, append);
kexec_debug = 1; // FIXME: for debugging only.
dbgprintf("%s:%d: command_line: %s\n", __func__, __LINE__,
--
2.1.0