[PATCH 1/3] kexec: Split kernel_version() to also be able to pass a release string
Thomas Renninger
trenn at suse.de
Tue Jan 22 10:02:13 EST 2013
No functional change, later patches need this.
Signed-off-by: Thomas Renninger <trenn at suse.de>
---
kexec/arch/i386/crashdump-x86.c | 2 +-
kexec/kernel_version.c | 33 +++++++++++++++++++--------------
kexec/kexec.h | 3 ++-
3 files changed, 22 insertions(+), 16 deletions(-)
diff --git a/kexec/arch/i386/crashdump-x86.c b/kexec/arch/i386/crashdump-x86.c
index 245402c..a900b03 100644
--- a/kexec/arch/i386/crashdump-x86.c
+++ b/kexec/arch/i386/crashdump-x86.c
@@ -63,7 +63,7 @@ static int get_kernel_page_offset(struct kexec_info *UNUSED(info),
int kv;
if (elf_info->machine == EM_X86_64) {
- kv = kernel_version();
+ kv = kernel_version_running();
if (kv < 0)
return -1;
diff --git a/kexec/kernel_version.c b/kexec/kernel_version.c
index 079312b..e27a0b7 100644
--- a/kexec/kernel_version.c
+++ b/kexec/kernel_version.c
@@ -6,18 +6,15 @@
#include <limits.h>
#include <stdlib.h>
-long kernel_version(void)
+#define unsupported_release(str) \
+ fprintf(stderr, "Unsupported release string: %s\n", str);
+
+long kernel_version(char *release_str)
{
- struct utsname utsname;
unsigned long major, minor, patch;
char *p;
- if (uname(&utsname) < 0) {
- fprintf(stderr, "uname failed: %s\n", strerror(errno));
- return -1;
- }
-
- p = utsname.release;
+ p = release_str;
major = strtoul(p, &p, 10);
if (major == ULONG_MAX) {
fprintf(stderr, "strtoul failed: %s\n", strerror(errno));
@@ -25,8 +22,7 @@ long kernel_version(void)
}
if (*p++ != '.') {
- fprintf(stderr, "Unsupported utsname.release: %s\n",
- utsname.release);
+ unsupported_release(release_str);
return -1;
}
@@ -37,8 +33,7 @@ long kernel_version(void)
}
if (*p++ != '.') {
- fprintf(stderr, "Unsupported utsname.release: %s\n",
- utsname.release);
+ unsupported_release(release_str);
return -1;
}
@@ -49,10 +44,20 @@ long kernel_version(void)
}
if (major >= 256 || minor >= 256 || patch >= 256) {
- fprintf(stderr, "Unsupported utsname.release: %s\n",
- utsname.release);
+ unsupported_release(release_str);
return -1;
}
return KERNEL_VERSION(major, minor, patch);
}
+
+long kernel_version_running(void)
+{
+ struct utsname utsname;
+
+ if (uname(&utsname) < 0) {
+ fprintf(stderr, "uname failed: %s\n", strerror(errno));
+ return -1;
+ }
+ return kernel_version(utsname.release);
+}
diff --git a/kexec/kexec.h b/kexec/kexec.h
index 94c62c1..ecc75d9 100644
--- a/kexec/kexec.h
+++ b/kexec/kexec.h
@@ -154,7 +154,8 @@ long physical_arch(void);
#define KERNEL_VERSION(major, minor, patch) \
(((major) << 16) | ((minor) << 8) | patch)
-long kernel_version(void);
+long kernel_version(char *release);
+long kernel_version_running(void);
void usage(void);
int get_memory_ranges(struct memory_range **range, int *ranges,
--
1.7.6.1
More information about the kexec
mailing list