From: Eugen Hristev <eugen.hristev@linaro.org>
To: linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org,
linux-mm@kvack.org, tglx@linutronix.de, andersson@kernel.org,
pmladek@suse.com, rdunlap@infradead.org, corbet@lwn.net,
david@redhat.com, mhocko@suse.com
Cc: tudor.ambarus@linaro.org, mukesh.ojha@oss.qualcomm.com,
linux-arm-kernel@lists.infradead.org,
linux-hardening@vger.kernel.org, jonechou@google.com,
rostedt@goodmis.org, linux-doc@vger.kernel.org,
devicetree@vger.kernel.org,
Eugen Hristev <eugen.hristev@linaro.org>
Subject: [RFC][PATCH v3 14/16] kernel/vmcoreinfo: Register kmemdump core image information
Date: Fri, 12 Sep 2025 18:08:53 +0300 [thread overview]
Message-ID: <20250912150855.2901211-15-eugen.hristev@linaro.org> (raw)
In-Reply-To: <20250912150855.2901211-1-eugen.hristev@linaro.org>
The coreimage generated by kmemdump requires some kernel information
in order to be successfully loaded by `crash` or gdb.
Register all this information through vmcoreinfo once vmcoreinfo is setup.
Signed-off-by: Eugen Hristev <eugen.hristev@linaro.org>
---
kernel/vmcore_info.c | 141 +++++++++++++++++++++++++++++++++++++++++++
1 file changed, 141 insertions(+)
diff --git a/kernel/vmcore_info.c b/kernel/vmcore_info.c
index 3e2e846ba9c8..1d83e95cf9be 100644
--- a/kernel/vmcore_info.c
+++ b/kernel/vmcore_info.c
@@ -15,6 +15,7 @@
#include <linux/memblock.h>
#include <linux/kmemleak.h>
#include <linux/kmemdump.h>
+#include <linux/sched/stat.h>
#include <asm/page.h>
#include <asm/sections.h>
@@ -24,6 +25,17 @@
#include "kallsyms_internal.h"
#include "kexec_internal.h"
+void sched_get_runqueues_area(void **start, size_t *size);
+
+extern unsigned int nr_irqs;
+extern unsigned long tainted_mask;
+extern unsigned int nr_swapfiles;
+
+#ifdef CONFIG_IKCONFIG_PROC
+extern char kernel_config_data;
+extern char kernel_config_data_end;
+#endif
+
/* vmcoreinfo stuff */
unsigned char *vmcoreinfo_data;
size_t vmcoreinfo_size;
@@ -121,8 +133,137 @@ EXPORT_SYMBOL(paddr_vmcoreinfo_note);
static void vmcoreinfo_kmemdump(void)
{
+ void *start;
+ size_t size;
+ int i;
+
kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_VMCOREINFO,
(void *)vmcoreinfo_data, vmcoreinfo_size);
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_linux_banner,
+ (void *)&linux_banner, banner_len);
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_init_uts_ns,
+ (void *)&init_uts_ns, sizeof(init_uts_ns));
+
+ sched_get_runqueues_area(&start, &size);
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_runqueues,
+ (void *)start, size);
+
+#ifdef CONFIG_IKCONFIG_PROC
+ /* Register 8 bytes before and after, to catch the marker too */
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_CONFIG,
+ (void *)&kernel_config_data - 8,
+ &kernel_config_data_end - &kernel_config_data + 16);
+#endif
+
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE___cpu_possible_mask,
+ (void *)&__cpu_possible_mask,
+ sizeof(__cpu_possible_mask));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE___cpu_active_mask,
+ (void *)&__cpu_active_mask,
+ sizeof(__cpu_active_mask));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE___cpu_online_mask,
+ (void *)&__cpu_online_mask,
+ sizeof(__cpu_online_mask));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE___cpu_present_mask,
+ (void *)&__cpu_present_mask,
+ sizeof(__cpu_present_mask));
+
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_nr_irqs,
+ (void *)&nr_irqs, sizeof(nr_irqs));
+
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_tainted_mask,
+ (void *)&tainted_mask, sizeof(tainted_mask));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_taint_flags,
+ (void *)&taint_flags, sizeof(taint_flags));
+
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_jiffies_64,
+ (void *)&jiffies_64, sizeof(jiffies_64));
+
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_nr_threads,
+ (void *)&nr_threads, sizeof(nr_threads));
+
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_node_states,
+ (void *)&node_states, sizeof(node_states));
+
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_init_mm,
+ (void *)&init_mm, sizeof(init_mm));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_init_mm_pgd,
+ (void *)&init_mm.pgd, sizeof(*init_mm.pgd));
+
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE__totalram_pages,
+ (void *)&_totalram_pages, sizeof(_totalram_pages));
+
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_nr_swapfiles,
+ (void *)&nr_swapfiles, sizeof(nr_swapfiles));
+
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE___per_cpu_offset,
+ (void *)&__per_cpu_offset, sizeof(__per_cpu_offset));
+
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_high_memory,
+ (void *)&high_memory, sizeof(high_memory));
+#ifdef CONFIG_NUMA
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_node_data,
+ (void *)&node_data,
+ MAX_NUMNODES * sizeof(struct pglist_data));
+
+ for (i = 0; i < MAX_NUMNODES; i++) {
+ if (!NODE_DATA(i))
+ continue;
+ kmemdump_register((void *)NODE_DATA(i),
+ roundup(sizeof(pg_data_t), SMP_CACHE_BYTES));
+ }
+#endif
+
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_mem_section,
+ (void *)&mem_section, sizeof(mem_section));
+ for (i = 0; i < NR_SECTION_ROOTS; i++) {
+ if (!mem_section[i])
+ continue;
+ kmemdump_register((void *)mem_section[i],
+ SECTIONS_PER_ROOT * sizeof(struct mem_section));
+ }
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_MEMSECT,
+ (void *)mem_section,
+ sizeof(struct mem_section *) * NR_SECTION_ROOTS);
+
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_kallsyms_num_syms,
+ (void *)&kallsyms_num_syms,
+ sizeof(kallsyms_num_syms));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_kallsyms_relative_base,
+ (void *)&kallsyms_relative_base,
+ sizeof(kallsyms_relative_base));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_kallsyms_offsets,
+ (void *)&kallsyms_offsets,
+ sizeof(&kallsyms_offsets));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_kallsyms_names,
+ (void *)&kallsyms_names,
+ sizeof(&kallsyms_names));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_kallsyms_token_table,
+ (void *)&kallsyms_token_table,
+ sizeof(&kallsyms_token_table));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_kallsyms_token_index,
+ (void *)&kallsyms_token_index,
+ sizeof(&kallsyms_token_index));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_kallsyms_markers,
+ (void *)&kallsyms_markers,
+ sizeof(&kallsyms_markers));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_kallsyms_seqs_of_names,
+ (void *)&kallsyms_seqs_of_names,
+ sizeof(&kallsyms_seqs_of_names));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE__sinittext,
+ (void *)&_sinittext, sizeof(&_sinittext));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE__einittext,
+ (void *)&_einittext, sizeof(&_einittext));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE__end,
+ (void *)&_end, sizeof(&_end));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE__text,
+ (void *)&_text, sizeof(&_text));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE__stext,
+ (void *)&_stext, sizeof(&_stext));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE__etext,
+ (void *)&_etext, sizeof(&_etext));
+ kmemdump_register_id(KMEMDUMP_ID_COREIMAGE_swapper_pg_dir,
+ (void *)&swapper_pg_dir, sizeof(&swapper_pg_dir));
}
static int __init crash_save_vmcoreinfo_init(void)
--
2.43.0
next prev parent reply other threads:[~2025-09-12 15:11 UTC|newest]
Thread overview: 42+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-09-12 15:08 [RFC][PATCH v3 00/16] Introduce kmemdump Eugen Hristev
2025-09-12 15:08 ` [RFC][PATCH v3 01/16] kmemdump: " Eugen Hristev
2025-09-12 15:08 ` [RFC][PATCH v3 02/16] Documentation: Add kmemdump Eugen Hristev
2025-09-12 15:08 ` [RFC][PATCH v3 03/16] kmemdump: Add coreimage ELF layer Eugen Hristev
2025-09-12 15:08 ` [RFC][PATCH v3 04/16] Documentation: kmemdump: Add section for coreimage ELF Eugen Hristev
2025-09-12 15:08 ` [RFC][PATCH v3 05/16] kernel/vmcore_info: Register dynamic information into Kmemdump Eugen Hristev
2025-09-12 15:08 ` [RFC][PATCH v3 06/16] kmemdump: Introduce qcom-minidump backend driver Eugen Hristev
2025-09-12 15:08 ` [RFC][PATCH v3 07/16] soc: qcom: smem: Add minidump device Eugen Hristev
2025-09-12 15:08 ` [RFC][PATCH v3 08/16] init/version: Add banner_len to save banner length Eugen Hristev
2025-09-12 15:08 ` [RFC][PATCH v3 09/16] genirq/irqdesc: Have nr_irqs as non-static Eugen Hristev
2025-09-16 21:10 ` Thomas Gleixner
2025-09-16 21:16 ` Thomas Gleixner
2025-09-17 5:43 ` Eugen Hristev
2025-09-17 7:16 ` David Hildenbrand
2025-09-17 14:10 ` Thomas Gleixner
2025-09-17 14:26 ` Eugen Hristev
2025-09-17 14:46 ` David Hildenbrand
2025-09-17 15:02 ` Eugen Hristev
2025-09-17 15:18 ` David Hildenbrand
2025-09-17 15:32 ` Eugen Hristev
2025-09-17 15:44 ` David Hildenbrand
2025-09-17 18:42 ` Thomas Gleixner
2025-09-17 19:03 ` David Hildenbrand
2025-09-18 8:23 ` Thomas Gleixner
2025-09-18 13:53 ` Eugen Hristev
2025-09-18 18:43 ` Randy Dunlap
2025-09-25 20:11 ` David Hildenbrand
2025-09-12 15:08 ` [RFC][PATCH v3 10/16] panic: Have tainted_mask " Eugen Hristev
2025-09-12 15:08 ` [RFC][PATCH v3 11/16] mm/swapfile: Have nr_swapfiles " Eugen Hristev
2025-09-12 15:08 ` [RFC][PATCH v3 12/16] printk: Register information into Kmemdump Eugen Hristev
2025-09-12 15:08 ` [RFC][PATCH v3 13/16] sched: Add sched_get_runqueues_area Eugen Hristev
2025-09-12 15:08 ` Eugen Hristev [this message]
2025-09-12 15:08 ` [RFC][PATCH v3 15/16] kmemdump: Add Kinfo backend driver Eugen Hristev
2025-09-16 5:48 ` Alexey Klimov
2025-09-22 10:01 ` Tudor Ambarus
2025-09-12 15:08 ` [RFC][PATCH v3 16/16] dt-bindings: Add Google Kinfo Eugen Hristev
2025-09-14 11:56 ` Krzysztof Kozlowski
2025-09-12 15:56 ` [RFC][PATCH v3 00/16] Introduce kmemdump David Hildenbrand
2025-09-12 18:35 ` Eugen Hristev
2025-09-16 7:49 ` Mukesh Ojha
2025-09-16 15:25 ` Luck, Tony
2025-09-16 15:27 ` Eugen Hristev
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=20250912150855.2901211-15-eugen.hristev@linaro.org \
--to=eugen.hristev@linaro.org \
--cc=andersson@kernel.org \
--cc=corbet@lwn.net \
--cc=david@redhat.com \
--cc=devicetree@vger.kernel.org \
--cc=jonechou@google.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-arm-msm@vger.kernel.org \
--cc=linux-doc@vger.kernel.org \
--cc=linux-hardening@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=mhocko@suse.com \
--cc=mukesh.ojha@oss.qualcomm.com \
--cc=pmladek@suse.com \
--cc=rdunlap@infradead.org \
--cc=rostedt@goodmis.org \
--cc=tglx@linutronix.de \
--cc=tudor.ambarus@linaro.org \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox