From: Eric DeVolder <eric.devolder@oracle.com>
To: horms@verge.net.au, kexec@lists.infradead.org,
andrew.cooper3@citrix.com, dyoung@redhat.com
Cc: daniel.kiper@oracle.com, konrad.wilk@oracle.com
Subject: [PATCH v2 07/12] crashdump/ppc: Add print_crashkernel_region_size() function
Date: Mon, 6 Feb 2017 13:42:19 -0600 [thread overview]
Message-ID: <1486410144-28595-8-git-send-email-eric.devolder@oracle.com> (raw)
In-Reply-To: <1486410144-28595-1-git-send-email-eric.devolder@oracle.com>
From: Daniel Kiper <daniel.kiper@oracle.com>
Follow similar x86 patch.
Signed-off-by: Daniel Kiper <daniel.kiper@oracle.com>
Signed-off-by: Eric DeVolder <eric.devolder@oracle.com>
---
kexec/arch/ppc/crashdump-powerpc.c | 34 +++++++++++++++++++++++++++-------
kexec/arch/ppc/kexec-ppc.c | 23 +++++++++++++++++++++++
kexec/arch/ppc/kexec-ppc.h | 1 +
3 files changed, 51 insertions(+), 7 deletions(-)
diff --git a/kexec/arch/ppc/crashdump-powerpc.c b/kexec/arch/ppc/crashdump-powerpc.c
index 3dc35eb..4c12452 100644
--- a/kexec/arch/ppc/crashdump-powerpc.c
+++ b/kexec/arch/ppc/crashdump-powerpc.c
@@ -397,14 +397,34 @@ void add_usable_mem_rgns(unsigned long long base, unsigned long long size)
usablemem_rgns.size, base, size);
}
+int get_crash_kernel_load_range(uint64_t *start, uint64_t *end)
+{
+ unsigned long long value;
+ if (get_devtree_value("/proc/device-tree/chosen/linux,crashkernel-base", &value)) {
+ *start = value;
+ }
+ else
+ *start = 0;
+ if (get_devtree_value("/proc/device-tree/chosen/linux,crashkernel-size", &value)) {
+ *end = *start + value - 1;
+ }
+ else
+ *end = 0;
+ return 0;
+}
+
int is_crashkernel_mem_reserved(void)
{
- int fd;
-
- fd = open("/proc/device-tree/chosen/linux,crashkernel-base", O_RDONLY);
- if (fd < 0)
- return 0;
- close(fd);
- return 1;
+ return get_devtree_value("/proc/device-tree/chosen/linux,crashkernel-base", NULL);
}
+void print_crashkernel_region_size(void)
+{
+ uint64_t start = 0, end = 0;
+
+ if (is_crashkernel_mem_reserved()) {
+ get_crash_kernel_load_range(&start, &end);
+ printf("%llu\n", end - start + 1);
+ } else
+ printf("0\n");
+}
diff --git a/kexec/arch/ppc/kexec-ppc.c b/kexec/arch/ppc/kexec-ppc.c
index d046110..78e8fb8 100644
--- a/kexec/arch/ppc/kexec-ppc.c
+++ b/kexec/arch/ppc/kexec-ppc.c
@@ -423,6 +423,29 @@ err_out:
return -1;
}
+int get_devtree_value (const char *fname, unsigned long long *pvalue)
+{
+ /* Return 1 if fname/value valid, 0 otherwise */
+ FILE *file;
+ char buf[MAXBYTES];
+ int rcode = 1, n = -1;
+ unsigned long long value = 0;
+ if ((file = fopen(fname, "r"))) {
+ n = fread(buf, 1, MAXBYTES, file);
+ fclose(file);
+ }
+ if (n == sizeof(uint32_t)) {
+ value = ((uint32_t *)buf)[0];
+ } else if (n == sizeof(uint64_t)) {
+ value = ((uint64_t *)buf)[0];
+ } else {
+ fprintf(stderr, "%s node has invalid size: %d\n", fname, n);
+ rcode = 0;
+ }
+ if (pvalue) *pvalue = value;
+ return rcode;
+}
+
/* Get devtree details and create exclude_range array
* Also create usablemem_ranges for KEXEC_ON_CRASH
*/
diff --git a/kexec/arch/ppc/kexec-ppc.h b/kexec/arch/ppc/kexec-ppc.h
index 904cf48..69189f0 100644
--- a/kexec/arch/ppc/kexec-ppc.h
+++ b/kexec/arch/ppc/kexec-ppc.h
@@ -71,6 +71,7 @@ extern unsigned char reuse_initrd;
extern const char *ramdisk;
/* Method to parse the memory/reg nodes in device-tree */
+extern int get_devtree_value (const char *fname, unsigned long long *pvalue);
extern unsigned long dt_address_cells, dt_size_cells;
extern int init_memory_region_info(void);
extern int read_memory_region_limits(int fd, unsigned long long *start,
--
2.7.4
_______________________________________________
kexec mailing list
kexec@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/kexec
next prev parent reply other threads:[~2017-02-06 19:40 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-02-06 19:42 [PATCH v2 00/12] crashdump: Add print_crashkernel_region_size() function Eric DeVolder
2017-02-06 19:42 ` [PATCH v2 01/12] crashdump/x86: " Eric DeVolder
2017-02-07 14:55 ` Daniel Kiper
2017-02-06 19:42 ` [PATCH v2 02/12] crashdump/arm: " Eric DeVolder
2017-02-06 19:42 ` [PATCH v2 03/12] crashdump/cris: " Eric DeVolder
2017-02-07 15:07 ` Daniel Kiper
2017-02-06 19:42 ` [PATCH v2 04/12] crashdump/ia64: " Eric DeVolder
2017-02-06 19:42 ` [PATCH v2 05/12] crashdump/m68k: " Eric DeVolder
2017-02-07 15:09 ` Daniel Kiper
2017-02-06 19:42 ` [PATCH v2 06/12] crashdump/mips: " Eric DeVolder
2017-02-06 19:42 ` Eric DeVolder [this message]
2017-02-07 16:06 ` [PATCH v2 07/12] crashdump/ppc: " Daniel Kiper
2017-02-06 19:42 ` [PATCH v2 08/12] crashdump/ppc64: " Eric DeVolder
2017-02-06 19:50 ` Konrad Rzeszutek Wilk
2017-02-07 16:09 ` Daniel Kiper
2017-02-06 19:42 ` [PATCH v2 09/12] crashdump/s390: " Eric DeVolder
2017-02-06 19:42 ` [PATCH v2 10/12] crashdump/sh: " Eric DeVolder
2017-02-06 19:42 ` [PATCH v2 11/12] kexec: Add option to get crash kernel region size Eric DeVolder
2017-02-06 19:42 ` [PATCH v2 12/12] " Eric DeVolder
2017-02-07 16:14 ` Daniel Kiper
2017-02-07 14:42 ` [PATCH v2 00/12] crashdump: Add print_crashkernel_region_size() function Daniel Kiper
2017-02-08 8:37 ` Pratyush Anand
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1486410144-28595-8-git-send-email-eric.devolder@oracle.com \
--to=eric.devolder@oracle.com \
--cc=andrew.cooper3@citrix.com \
--cc=daniel.kiper@oracle.com \
--cc=dyoung@redhat.com \
--cc=horms@verge.net.au \
--cc=kexec@lists.infradead.org \
--cc=konrad.wilk@oracle.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.