|
|
474a44 |
commit b9d76838372d1b4087bb506ce6da425afad68876
|
|
|
474a44 |
Author: Dave Anderson <anderson@redhat.com>
|
|
|
474a44 |
Date: Thu Jun 7 13:20:16 2018 -0400
|
|
|
474a44 |
|
|
|
474a44 |
If /proc/kcore gets selected for the live memory source because
|
|
|
474a44 |
/dev/mem was configured with CONFIG_STRICT_DEVMEM, its ELF header
|
|
|
474a44 |
contents are not displayed by "help -[dD]", and are not displayed
|
|
|
474a44 |
when the crash session is invoked with -d<number>". Without the
|
|
|
474a44 |
patch, the ELF contents are only displayed in those two situations
|
|
|
474a44 |
if "/proc/kcore" is explicitly entered on the crash command line.
|
|
|
474a44 |
(anderson@redhat.com)
|
|
|
474a44 |
|
|
|
474a44 |
diff --git a/netdump.c b/netdump.c
|
|
|
474a44 |
index 25683eb..1f3e26c 100644
|
|
|
474a44 |
--- a/netdump.c
|
|
|
474a44 |
+++ b/netdump.c
|
|
|
474a44 |
@@ -4334,11 +4334,8 @@ kcore_memory_dump(FILE *ofp)
|
|
|
474a44 |
Elf32_Phdr *lp32;
|
|
|
474a44 |
Elf64_Phdr *lp64;
|
|
|
474a44 |
|
|
|
474a44 |
- if (!(pkd->flags & KCORE_LOCAL))
|
|
|
474a44 |
- return FALSE;
|
|
|
474a44 |
-
|
|
|
474a44 |
fprintf(ofp, "proc_kcore_data:\n");
|
|
|
474a44 |
- fprintf(ofp, " flags: %lx (", nd->flags);
|
|
|
474a44 |
+ fprintf(ofp, " flags: %x (", pkd->flags);
|
|
|
474a44 |
others = 0;
|
|
|
474a44 |
if (pkd->flags & KCORE_LOCAL)
|
|
|
474a44 |
fprintf(ofp, "%sKCORE_LOCAL", others++ ? "|" : "");
|
|
|
474a44 |
commit c79a11fa10da94b71ddf341ec996c522fbd75237
|
|
|
474a44 |
Author: Dave Anderson <anderson@redhat.com>
|
|
|
474a44 |
Date: Fri Jun 8 14:31:08 2018 -0400
|
|
|
474a44 |
|
|
|
474a44 |
If the default live memory source /dev/mem is determined to be
|
|
|
474a44 |
unusable because the kernel was configured with CONFIG_STRICT_DEVMEM,
|
|
|
474a44 |
the first memory read during session initialization will fail. The
|
|
|
474a44 |
current behavior results in a readmem() error message, followed by two
|
|
|
474a44 |
notification messages that indicate that /dev/mem is restricted and
|
|
|
474a44 |
a switch to using /proc/kcore will be attempted; the readmem is
|
|
|
474a44 |
reattempted from /proc/kcore, and if successful, the session will
|
|
|
474a44 |
continue initialization. With this patch, the behavior will change
|
|
|
474a44 |
such that if the switch to /proc/kcore and the reattempted readmem()
|
|
|
474a44 |
are successful, no messages will be displayed unless the crash
|
|
|
474a44 |
session is invoked with "crash -d<number>".
|
|
|
474a44 |
(anderson@redhat.com)
|
|
|
474a44 |
|
|
|
474a44 |
diff --git a/kernel.c b/kernel.c
|
|
|
474a44 |
index 138a47f..3cd5bf1 100644
|
|
|
474a44 |
--- a/kernel.c
|
|
|
474a44 |
+++ b/kernel.c
|
|
|
474a44 |
@@ -882,7 +882,7 @@ cpu_maps_init(void)
|
|
|
474a44 |
{
|
|
|
474a44 |
int i, c, m, cpu, len;
|
|
|
474a44 |
char *buf;
|
|
|
474a44 |
- ulong *maskptr, addr;
|
|
|
474a44 |
+ ulong *maskptr, addr, error_handle;
|
|
|
474a44 |
struct mapinfo {
|
|
|
474a44 |
ulong cpu_flag;
|
|
|
474a44 |
char *name;
|
|
|
474a44 |
@@ -902,8 +902,9 @@ cpu_maps_init(void)
|
|
|
474a44 |
if (!(addr = cpu_map_addr(mapinfo[m].name)))
|
|
|
474a44 |
continue;
|
|
|
474a44 |
|
|
|
474a44 |
+ error_handle = pc->flags & DEVMEM ? RETURN_ON_ERROR|QUIET : RETURN_ON_ERROR;
|
|
|
474a44 |
if (!readmem(addr, KVADDR, buf, len,
|
|
|
474a44 |
- mapinfo[m].name, RETURN_ON_ERROR)) {
|
|
|
474a44 |
+ mapinfo[m].name, error_handle)) {
|
|
|
474a44 |
error(WARNING, "cannot read cpu_%s_map\n",
|
|
|
474a44 |
mapinfo[m].name);
|
|
|
474a44 |
continue;
|
|
|
474a44 |
diff --git a/memory.c b/memory.c
|
|
|
474a44 |
index 82f9cbf..2f568d5 100644
|
|
|
474a44 |
--- a/memory.c
|
|
|
474a44 |
+++ b/memory.c
|
|
|
474a44 |
@@ -2243,9 +2243,11 @@ readmem(ulonglong addr, int memtype, void *buffer, long size,
|
|
|
474a44 |
error(INFO, READ_ERRMSG, memtype_string(memtype, 0), addr, type);
|
|
|
474a44 |
if ((pc->flags & DEVMEM) && (kt->flags & PRE_KERNEL_INIT) &&
|
|
|
474a44 |
!(error_handle & NO_DEVMEM_SWITCH) && devmem_is_restricted() &&
|
|
|
474a44 |
- switch_to_proc_kcore())
|
|
|
474a44 |
+ switch_to_proc_kcore()) {
|
|
|
474a44 |
+ error_handle &= ~QUIET;
|
|
|
474a44 |
return(readmem(addr, memtype, bufptr, size,
|
|
|
474a44 |
type, error_handle));
|
|
|
474a44 |
+ }
|
|
|
474a44 |
goto readmem_error;
|
|
|
474a44 |
|
|
|
474a44 |
case PAGE_EXCLUDED:
|
|
|
474a44 |
@@ -2457,7 +2459,7 @@ devmem_is_restricted(void)
|
|
|
474a44 |
QUIET|RETURN_ON_ERROR|NO_DEVMEM_SWITCH))
|
|
|
474a44 |
restricted = TRUE;
|
|
|
474a44 |
|
|
|
474a44 |
- if (restricted)
|
|
|
474a44 |
+ if (restricted && CRASHDEBUG(1))
|
|
|
474a44 |
error(INFO,
|
|
|
474a44 |
"this kernel may be configured with CONFIG_STRICT_DEVMEM,"
|
|
|
474a44 |
" which\n renders /dev/mem unusable as a live memory "
|
|
|
474a44 |
@@ -2472,9 +2474,10 @@ switch_to_proc_kcore(void)
|
|
|
474a44 |
{
|
|
|
474a44 |
close(pc->mfd);
|
|
|
474a44 |
|
|
|
474a44 |
- if (file_exists("/proc/kcore", NULL))
|
|
|
474a44 |
- error(INFO, "trying /proc/kcore as an alternative to /dev/mem\n\n");
|
|
|
474a44 |
- else
|
|
|
474a44 |
+ if (file_exists("/proc/kcore", NULL)) {
|
|
|
474a44 |
+ if (CRASHDEBUG(1))
|
|
|
474a44 |
+ error(INFO, "trying /proc/kcore as an alternative to /dev/mem\n\n");
|
|
|
474a44 |
+ } else
|
|
|
474a44 |
return FALSE;
|
|
|
474a44 |
|
|
|
474a44 |
if ((pc->mfd = open("/proc/kcore", O_RDONLY)) < 0) {
|
|
|
474a44 |
diff --git a/ppc64.c b/ppc64.c
|
|
|
474a44 |
index 0b04187..0dd8a2a 100644
|
|
|
474a44 |
--- a/ppc64.c
|
|
|
474a44 |
+++ b/ppc64.c
|
|
|
474a44 |
@@ -1,7 +1,7 @@
|
|
|
474a44 |
/* ppc64.c -- core analysis suite
|
|
|
474a44 |
*
|
|
|
474a44 |
- * Copyright (C) 2004-2015,2017 David Anderson
|
|
|
474a44 |
- * Copyright (C) 2004-2015,2017 Red Hat, Inc. All rights reserved.
|
|
|
474a44 |
+ * Copyright (C) 2004-2015,2018 David Anderson
|
|
|
474a44 |
+ * Copyright (C) 2004-2015,2018 Red Hat, Inc. All rights reserved.
|
|
|
474a44 |
* Copyright (C) 2004, 2006 Haren Myneni, IBM Corporation
|
|
|
474a44 |
*
|
|
|
474a44 |
* This program is free software; you can redistribute it and/or modify
|
|
|
474a44 |
@@ -343,8 +343,9 @@ ppc64_init(int when)
|
|
|
474a44 |
|
|
|
474a44 |
if (symbol_exists("vmemmap_populate")) {
|
|
|
474a44 |
if (symbol_exists("vmemmap")) {
|
|
|
474a44 |
- get_symbol_data("vmemmap", sizeof(void *),
|
|
|
474a44 |
- &machdep->machspec->vmemmap_base);
|
|
|
474a44 |
+ readmem(symbol_value("vmemmap"), KVADDR,
|
|
|
474a44 |
+ &machdep->machspec->vmemmap_base,
|
|
|
474a44 |
+ sizeof(void *), "vmemmap", QUIET|FAULT_ON_ERROR);
|
|
|
474a44 |
} else
|
|
|
474a44 |
machdep->machspec->vmemmap_base =
|
|
|
474a44 |
VMEMMAP_REGION_ID << REGION_SHIFT;
|
|
|
474a44 |
diff --git a/x86_64.c b/x86_64.c
|
|
|
474a44 |
index 54b6539..e01082b 100644
|
|
|
474a44 |
--- a/x86_64.c
|
|
|
474a44 |
+++ b/x86_64.c
|
|
|
474a44 |
@@ -356,7 +356,7 @@ x86_64_init(int when)
|
|
|
474a44 |
machdep->flags |= RANDOMIZED;
|
|
|
474a44 |
readmem(symbol_value("page_offset_base"), KVADDR,
|
|
|
474a44 |
&machdep->machspec->page_offset, sizeof(ulong),
|
|
|
474a44 |
- "page_offset_base", FAULT_ON_ERROR);
|
|
|
474a44 |
+ "page_offset_base", QUIET|FAULT_ON_ERROR);
|
|
|
474a44 |
machdep->kvbase = machdep->machspec->page_offset;
|
|
|
474a44 |
machdep->identity_map_base = machdep->machspec->page_offset;
|
|
|
474a44 |
}
|