import crash-7.3.0-2.el8
# Conflicts: # SOURCES/lzo_snappy.patch # SOURCES/rhel8_build.patch
This commit is contained in:
parent
7a2a368afc
commit
d1e5150f0d
@ -1,2 +1,2 @@
|
||||
20865107a4a2ffcb31d9b2f390f72e1dcc3a5dbc SOURCES/crash-7.2.9.tar.gz
|
||||
35a06244e58606ebf2b5612fbfcb51301bd5877a SOURCES/crash-7.3.0.tar.gz
|
||||
026f4c9e1c8152a2773354551c523acd32d7f00e SOURCES/gdb-7.6.tar.gz
|
||||
|
2
.gitignore
vendored
2
.gitignore
vendored
@ -1,2 +1,2 @@
|
||||
SOURCES/crash-7.2.9.tar.gz
|
||||
SOURCES/crash-7.3.0.tar.gz
|
||||
SOURCES/gdb-7.6.tar.gz
|
||||
|
26
SOURCES/lzo_snappy.patch
Normal file
26
SOURCES/lzo_snappy.patch
Normal file
@ -0,0 +1,26 @@
|
||||
diff --git crash-7.3.0/Makefile crash-7.3.0/Makefile
|
||||
index 745541012f43..d0574d8f07d3 100644
|
||||
--- crash-7.3.0/Makefile
|
||||
+++ crash-7.3.0/Makefile
|
||||
@@ -228,7 +228,7 @@ all: make_configure
|
||||
gdb_merge: force
|
||||
@if [ ! -f ${GDB}/README ]; then \
|
||||
make --no-print-directory gdb_unzip; fi
|
||||
- @echo "${LDFLAGS} -lz -ldl -rdynamic" > ${GDB}/gdb/mergelibs
|
||||
+ @echo "${LDFLAGS} -lz -llzo2 -lsnappy -ldl -rdynamic" > ${GDB}/gdb/mergelibs
|
||||
@echo "../../${PROGRAM} ../../${PROGRAM}lib.a" > ${GDB}/gdb/mergeobj
|
||||
@rm -f ${PROGRAM}
|
||||
@if [ ! -f ${GDB}/config.status ]; then \
|
||||
diff --git crash-7.3.0/diskdump.c crash-7.3.0/diskdump.c
|
||||
index e88243e616cc..9ccf7039231b 100644
|
||||
--- crash-7.3.0/diskdump.c
|
||||
+++ crash-7.3.0/diskdump.c
|
||||
@@ -23,6 +23,8 @@
|
||||
* GNU General Public License for more details.
|
||||
*/
|
||||
|
||||
+#define LZO
|
||||
+#define SNAPPY
|
||||
#include "defs.h"
|
||||
#include "diskdump.h"
|
||||
#include "xen_dom0.h"
|
@ -1,13 +1,16 @@
|
||||
commit fe84f31c36bff278f68553d521c983836c5670e2
|
||||
Author: Bhupesh Sharma <bhsharma@redhat.com>
|
||||
Date: Tue Dec 1 02:23:53 2020 +0530
|
||||
From 1bc151ee1304318ecb36d6158afe40852bc4b7f4 Mon Sep 17 00:00:00 2001
|
||||
From: Bhupesh Sharma <bhsharma@redhat.com>
|
||||
Date: Tue, 1 Dec 2020 02:23:53 +0530
|
||||
Subject: [PATCH] arm64 crash fix for older kernels
|
||||
|
||||
arm64 crash fix for older kernels
|
||||
|
||||
Signed-off-by: Bhupesh Sharma <bhsharma@redhat.com>
|
||||
Signed-off-by: Bhupesh Sharma <bhsharma@redhat.com>
|
||||
---
|
||||
arm64.c | 512 +++++++++++---------------------------------------------
|
||||
defs.h | 18 +-
|
||||
2 files changed, 102 insertions(+), 428 deletions(-)
|
||||
|
||||
diff --git a/arm64.c b/arm64.c
|
||||
index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
index 4787fa61e3e5..68347b131aef 100644
|
||||
--- a/arm64.c
|
||||
+++ b/arm64.c
|
||||
@@ -27,13 +27,9 @@
|
||||
@ -204,7 +207,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
break;
|
||||
}
|
||||
}
|
||||
@@ -655,20 +619,9 @@ arm64_dump_machdep_table(ulong arg)
|
||||
@@ -657,20 +621,9 @@ arm64_dump_machdep_table(ulong arg)
|
||||
|
||||
fprintf(fp, " machspec: %lx\n", (ulong)ms);
|
||||
fprintf(fp, " VA_BITS: %ld\n", ms->VA_BITS);
|
||||
@ -228,7 +231,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
else
|
||||
fprintf(fp, "(unused)\n");
|
||||
fprintf(fp, " userspace_top: %016lx\n", ms->userspace_top);
|
||||
@@ -757,14 +710,12 @@ arm64_parse_machdep_arg_l(char *argstring, char *param, ulong *value)
|
||||
@@ -759,14 +712,12 @@ arm64_parse_machdep_arg_l(char *argstring, char *param, ulong *value)
|
||||
int flags = RETURN_ON_ERROR | QUIET;
|
||||
int err = 0;
|
||||
|
||||
@ -246,7 +249,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
} else {
|
||||
*value = htol(p, flags, &err);
|
||||
}
|
||||
@@ -830,12 +781,6 @@ arm64_parse_cmdline_args(void)
|
||||
@@ -832,12 +783,6 @@ arm64_parse_cmdline_args(void)
|
||||
"setting max_physmem_bits to: %ld\n\n",
|
||||
machdep->max_physmem_bits);
|
||||
continue;
|
||||
@ -259,7 +262,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
}
|
||||
|
||||
error(WARNING, "ignoring --machdep option: %s\n",
|
||||
@@ -844,60 +789,11 @@ arm64_parse_cmdline_args(void)
|
||||
@@ -846,60 +791,11 @@ arm64_parse_cmdline_args(void)
|
||||
}
|
||||
}
|
||||
|
||||
@ -321,7 +324,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
|
||||
if (ms->kimage_voffset) /* vmcoreinfo, ioctl, or --machdep override */
|
||||
return;
|
||||
@@ -905,6 +801,7 @@ arm64_calc_kimage_voffset(void)
|
||||
@@ -907,6 +803,7 @@ arm64_calc_kimage_voffset(void)
|
||||
if (ACTIVE()) {
|
||||
char buf[BUFSIZE];
|
||||
char *p1;
|
||||
@ -329,7 +332,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
FILE *iomem;
|
||||
ulong kimage_voffset, vaddr;
|
||||
|
||||
@@ -945,24 +842,9 @@ arm64_calc_kimage_voffset(void)
|
||||
@@ -947,24 +844,9 @@ arm64_calc_kimage_voffset(void)
|
||||
if (errflag)
|
||||
return;
|
||||
|
||||
@ -357,7 +360,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
error(WARNING,
|
||||
"kimage_voffset cannot be determined from the dumpfile.\n");
|
||||
error(CONT,
|
||||
@@ -978,25 +860,6 @@ arm64_calc_kimage_voffset(void)
|
||||
@@ -980,25 +862,6 @@ arm64_calc_kimage_voffset(void)
|
||||
ms->kimage_voffset += (kt->relocate * -1);
|
||||
}
|
||||
|
||||
@ -383,7 +386,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
static void
|
||||
arm64_calc_phys_offset(void)
|
||||
{
|
||||
@@ -1020,16 +883,10 @@ arm64_calc_phys_offset(void)
|
||||
@@ -1022,16 +885,10 @@ arm64_calc_phys_offset(void)
|
||||
physaddr_t paddr;
|
||||
ulong vaddr;
|
||||
struct syment *sp;
|
||||
@ -400,7 +403,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
vaddr = symbol_value_from_proc_kallsyms("memstart_addr");
|
||||
if (vaddr == BADVAL)
|
||||
vaddr = sp->value;
|
||||
@@ -1092,31 +949,6 @@ arm64_calc_phys_offset(void)
|
||||
@@ -1094,31 +951,6 @@ arm64_calc_phys_offset(void)
|
||||
fprintf(fp, "using %lx as phys_offset\n", ms->phys_offset);
|
||||
}
|
||||
|
||||
@ -432,7 +435,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
|
||||
/*
|
||||
* Determine PHYS_OFFSET either by reading VMCOREINFO or the kernel
|
||||
@@ -1172,14 +1004,9 @@ ulong
|
||||
@@ -1174,14 +1006,9 @@ ulong
|
||||
arm64_VTOP(ulong addr)
|
||||
{
|
||||
if (machdep->flags & NEW_VMEMMAP) {
|
||||
@ -449,7 +452,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
else if (machdep->machspec->kimage_voffset)
|
||||
return addr - machdep->machspec->kimage_voffset;
|
||||
else /* no randomness */
|
||||
@@ -1253,11 +1080,6 @@ arm64_uvtop(struct task_context *tc, ulong uvaddr, physaddr_t *paddr, int verbos
|
||||
@@ -1255,11 +1082,6 @@ arm64_uvtop(struct task_context *tc, ulong uvaddr, physaddr_t *paddr, int verbos
|
||||
}
|
||||
}
|
||||
|
||||
@ -458,10 +461,10 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
-#define PTE_TO_PHYS(pteval) (machdep->max_physmem_bits == 52 ? \
|
||||
- (((pteval & PTE_ADDR_LOW) | ((pteval & PTE_ADDR_HIGH) << 36))) : (pteval & PTE_ADDR_LOW))
|
||||
-
|
||||
#define PUD_TYPE_MASK 3
|
||||
#define PUD_TYPE_SECT 1
|
||||
#define PMD_TYPE_MASK 3
|
||||
#define PMD_TYPE_SECT 1
|
||||
#define PMD_TYPE_TABLE 2
|
||||
@@ -1350,7 +1172,7 @@ arm64_vtop_3level_64k(ulong pgd, ulong vaddr, physaddr_t *paddr, int verbose)
|
||||
@@ -1355,7 +1177,7 @@ arm64_vtop_3level_64k(ulong pgd, ulong vaddr, physaddr_t *paddr, int verbose)
|
||||
* #define __PAGETABLE_PUD_FOLDED
|
||||
*/
|
||||
|
||||
@ -470,7 +473,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
FILL_PMD(pmd_base, KVADDR, PTRS_PER_PMD_L3_64K * sizeof(ulong));
|
||||
pmd_ptr = pmd_base + (((vaddr) >> PMD_SHIFT_L3_64K) & (PTRS_PER_PMD_L3_64K - 1));
|
||||
pmd_val = ULONG(machdep->pmd + PAGEOFFSET(pmd_ptr));
|
||||
@@ -1360,7 +1182,7 @@ arm64_vtop_3level_64k(ulong pgd, ulong vaddr, physaddr_t *paddr, int verbose)
|
||||
@@ -1365,7 +1187,7 @@ arm64_vtop_3level_64k(ulong pgd, ulong vaddr, physaddr_t *paddr, int verbose)
|
||||
goto no_page;
|
||||
|
||||
if ((pmd_val & PMD_TYPE_MASK) == PMD_TYPE_SECT) {
|
||||
@ -479,7 +482,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
if (verbose) {
|
||||
fprintf(fp, " PAGE: %lx (512MB)\n\n", sectionbase);
|
||||
arm64_translate_pte(pmd_val, 0, 0);
|
||||
@@ -1369,7 +1191,7 @@ arm64_vtop_3level_64k(ulong pgd, ulong vaddr, physaddr_t *paddr, int verbose)
|
||||
@@ -1374,7 +1196,7 @@ arm64_vtop_3level_64k(ulong pgd, ulong vaddr, physaddr_t *paddr, int verbose)
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
@ -488,7 +491,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
FILL_PTBL(pte_base, KVADDR, PTRS_PER_PTE_L3_64K * sizeof(ulong));
|
||||
pte_ptr = pte_base + (((vaddr) >> machdep->pageshift) & (PTRS_PER_PTE_L3_64K - 1));
|
||||
pte_val = ULONG(machdep->ptbl + PAGEOFFSET(pte_ptr));
|
||||
@@ -1379,7 +1201,7 @@ arm64_vtop_3level_64k(ulong pgd, ulong vaddr, physaddr_t *paddr, int verbose)
|
||||
@@ -1384,7 +1206,7 @@ arm64_vtop_3level_64k(ulong pgd, ulong vaddr, physaddr_t *paddr, int verbose)
|
||||
goto no_page;
|
||||
|
||||
if (pte_val & PTE_VALID) {
|
||||
@ -497,7 +500,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
if (verbose) {
|
||||
fprintf(fp, " PAGE: %lx\n\n", PAGEBASE(*paddr));
|
||||
arm64_translate_pte(pte_val, 0, 0);
|
||||
@@ -1682,11 +1504,10 @@ arm64_stackframe_init(void)
|
||||
@@ -1696,11 +1518,10 @@ arm64_stackframe_init(void)
|
||||
machdep->machspec->kern_eframe_offset = SIZE(pt_regs);
|
||||
}
|
||||
|
||||
@ -513,7 +516,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
if ((sp1 = kernel_symbol_search("__irqentry_text_start")) &&
|
||||
(sp2 = kernel_symbol_search("__irqentry_text_end"))) {
|
||||
machdep->machspec->__irqentry_text_start = sp1->value;
|
||||
@@ -1812,14 +1633,13 @@ static int
|
||||
@@ -1826,14 +1647,13 @@ static int
|
||||
arm64_is_kernel_exception_frame(struct bt_info *bt, ulong stkptr)
|
||||
{
|
||||
struct arm64_pt_regs *regs;
|
||||
@ -529,7 +532,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
switch (regs->pstate & PSR_MODE_MASK)
|
||||
{
|
||||
case PSR_MODE_EL1t:
|
||||
@@ -1896,38 +1716,20 @@ arm64_eframe_search(struct bt_info *bt)
|
||||
@@ -1910,38 +1730,20 @@ arm64_eframe_search(struct bt_info *bt)
|
||||
return count;
|
||||
}
|
||||
|
||||
@ -572,7 +575,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
@@ -1963,7 +1765,6 @@ arm64_print_stackframe_entry(struct bt_info *bt, int level, struct arm64_stackfr
|
||||
@@ -1977,7 +1779,6 @@ arm64_print_stackframe_entry(struct bt_info *bt, int level, struct arm64_stackfr
|
||||
* See, for example, "bl schedule" before ret_to_user().
|
||||
*/
|
||||
branch_pc = frame->pc - 4;
|
||||
@ -580,7 +583,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
name = closest_symbol(branch_pc);
|
||||
name_plus_offset = NULL;
|
||||
|
||||
@@ -2175,7 +1976,7 @@ arm64_unwind_frame(struct bt_info *bt, struct arm64_stackframe *frame)
|
||||
@@ -2189,7 +1990,7 @@ arm64_unwind_frame(struct bt_info *bt, struct arm64_stackframe *frame)
|
||||
unsigned long stack_mask;
|
||||
unsigned long irq_stack_ptr, orig_sp;
|
||||
struct arm64_pt_regs *ptregs;
|
||||
@ -589,7 +592,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
|
||||
stack_mask = (unsigned long)(ARM64_STACK_SIZE) - 1;
|
||||
fp = frame->fp;
|
||||
@@ -2189,8 +1990,6 @@ arm64_unwind_frame(struct bt_info *bt, struct arm64_stackframe *frame)
|
||||
@@ -2203,8 +2004,6 @@ arm64_unwind_frame(struct bt_info *bt, struct arm64_stackframe *frame)
|
||||
frame->sp = fp + 0x10;
|
||||
frame->fp = GET_STACK_ULONG(fp);
|
||||
frame->pc = GET_STACK_ULONG(fp + 8);
|
||||
@ -598,7 +601,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
|
||||
if ((frame->fp == 0) && (frame->pc == 0))
|
||||
return FALSE;
|
||||
@@ -2242,6 +2041,7 @@ arm64_unwind_frame(struct bt_info *bt, struct arm64_stackframe *frame)
|
||||
@@ -2256,6 +2055,7 @@ arm64_unwind_frame(struct bt_info *bt, struct arm64_stackframe *frame)
|
||||
* irq_stack_ptr = IRQ_STACK_PTR(raw_smp_processor_id());
|
||||
* orig_sp = IRQ_STACK_TO_TASK_STACK(irq_stack_ptr); (pt_regs pointer on process stack)
|
||||
*/
|
||||
@ -606,7 +609,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
irq_stack_ptr = ms->irq_stacks[bt->tc->processor] + ms->irq_stack_size - 16;
|
||||
|
||||
if (frame->sp == irq_stack_ptr) {
|
||||
@@ -2843,8 +2643,6 @@ arm64_print_text_symbols(struct bt_info *bt, struct arm64_stackframe *frame, FIL
|
||||
@@ -2857,8 +2657,6 @@ arm64_print_text_symbols(struct bt_info *bt, struct arm64_stackframe *frame, FIL
|
||||
char buf2[BUFSIZE];
|
||||
char *name;
|
||||
ulong start;
|
||||
@ -615,7 +618,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
|
||||
if (bt->flags & BT_TEXT_SYMBOLS_ALL)
|
||||
start = bt->stackbase;
|
||||
@@ -2859,10 +2657,8 @@ arm64_print_text_symbols(struct bt_info *bt, struct arm64_stackframe *frame, FIL
|
||||
@@ -2873,10 +2671,8 @@ arm64_print_text_symbols(struct bt_info *bt, struct arm64_stackframe *frame, FIL
|
||||
|
||||
for (i = (start - bt->stackbase)/sizeof(ulong); i < LONGS_PER_STACK; i++) {
|
||||
up = (ulong *)(&bt->stackbuf[i*sizeof(ulong)]);
|
||||
@ -628,7 +631,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
fprintf(ofp, " %s[%s] %s at %lx",
|
||||
bt->flags & BT_ERROR_MASK ?
|
||||
" " : "",
|
||||
@@ -2871,13 +2667,13 @@ arm64_print_text_symbols(struct bt_info *bt, struct arm64_stackframe *frame, FIL
|
||||
@@ -2885,13 +2681,13 @@ arm64_print_text_symbols(struct bt_info *bt, struct arm64_stackframe *frame, FIL
|
||||
MKSTR(bt->stackbase +
|
||||
(i * sizeof(long)))),
|
||||
bt->flags & BT_SYMBOL_OFFSET ?
|
||||
@ -646,7 +649,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -3180,7 +2976,6 @@ arm64_print_exception_frame(struct bt_info *bt, ulong pt_regs, int mode, FILE *o
|
||||
@@ -3194,7 +2990,6 @@ arm64_print_exception_frame(struct bt_info *bt, ulong pt_regs, int mode, FILE *o
|
||||
struct syment *sp;
|
||||
ulong LR, SP, offset;
|
||||
char buf[BUFSIZE];
|
||||
@ -654,7 +657,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
|
||||
if (CRASHDEBUG(1))
|
||||
fprintf(ofp, "pt_regs: %lx\n", pt_regs);
|
||||
@@ -3196,8 +2991,6 @@ arm64_print_exception_frame(struct bt_info *bt, ulong pt_regs, int mode, FILE *o
|
||||
@@ -3210,8 +3005,6 @@ arm64_print_exception_frame(struct bt_info *bt, ulong pt_regs, int mode, FILE *o
|
||||
rows = 4;
|
||||
} else {
|
||||
LR = regs->regs[30];
|
||||
@ -663,7 +666,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
SP = regs->sp;
|
||||
top_reg = 29;
|
||||
is_64_bit = TRUE;
|
||||
@@ -3345,7 +3138,7 @@ arm64_translate_pte(ulong pte, void *physaddr, ulonglong unused)
|
||||
@@ -3359,7 +3152,7 @@ arm64_translate_pte(ulong pte, void *physaddr, ulonglong unused)
|
||||
char *arglist[MAXARGS];
|
||||
int page_present;
|
||||
|
||||
@ -672,7 +675,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
page_present = pte & (PTE_VALID | machdep->machspec->PTE_PROT_NONE);
|
||||
|
||||
if (physaddr) {
|
||||
@@ -3611,8 +3404,8 @@ arm64_display_machine_stats(void)
|
||||
@@ -3625,8 +3418,8 @@ arm64_display_machine_stats(void)
|
||||
fprintf(fp, " HZ: %d\n", machdep->hz);
|
||||
fprintf(fp, " PAGE SIZE: %d\n", PAGESIZE());
|
||||
fprintf(fp, "KERNEL VIRTUAL BASE: %lx\n", machdep->machspec->page_offset);
|
||||
@ -682,7 +685,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
fprintf(fp, "KERNEL VMEMMAP BASE: %lx\n", machdep->machspec->vmemmap_vaddr);
|
||||
fprintf(fp, " KERNEL STACK SIZE: %ld\n", STACKSIZE());
|
||||
if (machdep->machspec->irq_stack_size) {
|
||||
@@ -3642,7 +3435,7 @@ arm64_get_smp_cpus(void)
|
||||
@@ -3656,7 +3449,7 @@ arm64_get_smp_cpus(void)
|
||||
/*
|
||||
* Retrieve task registers for the time of the crash.
|
||||
*/
|
||||
@ -691,7 +694,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
arm64_get_crash_notes(void)
|
||||
{
|
||||
struct machine_specific *ms = machdep->machspec;
|
||||
@@ -3651,10 +3444,10 @@ arm64_get_crash_notes(void)
|
||||
@@ -3665,10 +3458,10 @@ arm64_get_crash_notes(void)
|
||||
ulong offset;
|
||||
char *buf, *p;
|
||||
ulong *notes_ptrs;
|
||||
@ -704,7 +707,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
|
||||
crash_notes = symbol_value("crash_notes");
|
||||
|
||||
@@ -3666,9 +3459,9 @@ arm64_get_crash_notes(void)
|
||||
@@ -3680,9 +3473,9 @@ arm64_get_crash_notes(void)
|
||||
*/
|
||||
if (!readmem(crash_notes, KVADDR, ¬es_ptrs[kt->cpus-1],
|
||||
sizeof(notes_ptrs[kt->cpus-1]), "crash_notes", RETURN_ON_ERROR)) {
|
||||
@ -716,7 +719,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
}
|
||||
|
||||
if (symbol_exists("__per_cpu_offset")) {
|
||||
@@ -3684,11 +3477,12 @@ arm64_get_crash_notes(void)
|
||||
@@ -3698,11 +3491,12 @@ arm64_get_crash_notes(void)
|
||||
if (!(ms->panic_task_regs = calloc((size_t)kt->cpus, sizeof(struct arm64_pt_regs))))
|
||||
error(FATAL, "cannot calloc panic_task_regs space\n");
|
||||
|
||||
@ -732,7 +735,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
}
|
||||
|
||||
/*
|
||||
@@ -3718,24 +3512,19 @@ arm64_get_crash_notes(void)
|
||||
@@ -3732,24 +3526,19 @@ arm64_get_crash_notes(void)
|
||||
note->n_descsz == notesz)
|
||||
BCOPY((char *)note, buf, notesz);
|
||||
} else {
|
||||
@ -764,7 +767,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
}
|
||||
|
||||
/*
|
||||
@@ -3748,17 +3537,18 @@ arm64_get_crash_notes(void)
|
||||
@@ -3762,17 +3551,18 @@ arm64_get_crash_notes(void)
|
||||
|
||||
BCOPY(p + OFFSET(elf_prstatus_pr_reg), &ms->panic_task_regs[i],
|
||||
sizeof(struct arm64_pt_regs));
|
||||
@ -789,7 +792,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
}
|
||||
|
||||
static void
|
||||
@@ -3882,13 +3672,9 @@ arm64_IS_VMALLOC_ADDR(ulong vaddr)
|
||||
@@ -3896,13 +3686,9 @@ arm64_IS_VMALLOC_ADDR(ulong vaddr)
|
||||
(vaddr <= machdep->machspec->kimage_end))
|
||||
return FALSE;
|
||||
|
||||
@ -804,7 +807,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
(vaddr >= ms->modules_vaddr && vaddr <= ms->modules_end));
|
||||
}
|
||||
|
||||
@@ -3897,57 +3683,9 @@ arm64_calc_VA_BITS(void)
|
||||
@@ -3911,57 +3697,9 @@ arm64_calc_VA_BITS(void)
|
||||
{
|
||||
int bitval;
|
||||
struct syment *sp;
|
||||
@ -863,7 +866,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
if (!(sp = symbol_search("swapper_pg_dir")) &&
|
||||
!(sp = symbol_search("idmap_pg_dir")) &&
|
||||
!(sp = symbol_search("_text")) &&
|
||||
@@ -3976,12 +3714,14 @@ arm64_calc_VA_BITS(void)
|
||||
@@ -3990,12 +3728,14 @@ arm64_calc_VA_BITS(void)
|
||||
/*
|
||||
* Verify against dumpfiles that export VA_BITS in vmcoreinfo
|
||||
*/
|
||||
@ -884,7 +887,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
|
||||
if (CRASHDEBUG(1))
|
||||
fprintf(fp, "VA_BITS: %ld\n", machdep->machspec->VA_BITS);
|
||||
@@ -3999,15 +3739,6 @@ arm64_calc_VA_BITS(void)
|
||||
@@ -4013,15 +3753,6 @@ arm64_calc_VA_BITS(void)
|
||||
*
|
||||
* Since VMEMMAP_SIZE is dependent upon the size of a struct page,
|
||||
* the two ranges cannot be determined until POST_GDB.
|
||||
@ -900,7 +903,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
*/
|
||||
|
||||
#define ALIGN(x, a) __ALIGN_KERNEL((x), (a))
|
||||
@@ -4019,23 +3750,10 @@ static void
|
||||
@@ -4033,23 +3764,10 @@ static void
|
||||
arm64_calc_virtual_memory_ranges(void)
|
||||
{
|
||||
struct machine_specific *ms = machdep->machspec;
|
||||
@ -926,7 +929,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
if (THIS_KERNEL_VERSION < LINUX(3,17,0)) /* use original hardwired values */
|
||||
return;
|
||||
|
||||
@@ -4054,24 +3772,8 @@ arm64_calc_virtual_memory_ranges(void)
|
||||
@@ -4068,24 +3786,8 @@ arm64_calc_virtual_memory_ranges(void)
|
||||
break;
|
||||
}
|
||||
|
||||
@ -952,7 +955,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
vmemmap_size = 1UL << (ms->VA_BITS - machdep->pageshift - 1
|
||||
+ STRUCT_PAGE_MAX_SHIFT);
|
||||
else
|
||||
@@ -4095,7 +3797,7 @@ arm64_calc_virtual_memory_ranges(void)
|
||||
@@ -4109,7 +3811,7 @@ arm64_calc_virtual_memory_ranges(void)
|
||||
static int
|
||||
arm64_is_uvaddr(ulong addr, struct task_context *tc)
|
||||
{
|
||||
@ -961,7 +964,7 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
}
|
||||
|
||||
|
||||
@@ -4120,20 +3822,6 @@ arm64_swp_offset(ulong pte)
|
||||
@@ -4134,20 +3836,6 @@ arm64_swp_offset(ulong pte)
|
||||
return pte;
|
||||
}
|
||||
|
||||
@ -983,10 +986,10 @@ index fdf77bd5e0c1..6d825c9e67de 100644
|
||||
|
||||
|
||||
diff --git a/defs.h b/defs.h
|
||||
index 95949507cae4..48f5e05e32f3 100644
|
||||
index 396d61aaf532..897386160abd 100644
|
||||
--- a/defs.h
|
||||
+++ b/defs.h
|
||||
@@ -3052,7 +3052,7 @@ typedef u64 pte_t;
|
||||
@@ -3087,7 +3087,7 @@ typedef u64 pte_t;
|
||||
#define MACHINE_TYPE "ARM64"
|
||||
|
||||
#define PTOV(X) \
|
||||
@ -995,7 +998,7 @@ index 95949507cae4..48f5e05e32f3 100644
|
||||
|
||||
#define VTOP(X) arm64_VTOP((ulong)(X))
|
||||
|
||||
@@ -3186,17 +3186,9 @@ typedef signed int s32;
|
||||
@@ -3221,17 +3221,9 @@ typedef signed int s32;
|
||||
*/
|
||||
#define ARM64_VA_START ((0xffffffffffffffffUL) \
|
||||
<< machdep->machspec->VA_BITS)
|
||||
@ -1013,7 +1016,7 @@ index 95949507cae4..48f5e05e32f3 100644
|
||||
|
||||
/* only used for v4.6 or later */
|
||||
#define ARM64_MODULES_VSIZE MEGABYTES(128)
|
||||
@@ -3299,11 +3291,7 @@ struct machine_specific {
|
||||
@@ -3334,11 +3326,7 @@ struct machine_specific {
|
||||
ulong kern_eframe_offset;
|
||||
ulong machine_kexec_start;
|
||||
ulong machine_kexec_end;
|
||||
@ -1026,7 +1029,7 @@ index 95949507cae4..48f5e05e32f3 100644
|
||||
};
|
||||
|
||||
struct arm64_stackframe {
|
||||
@@ -3552,8 +3540,6 @@ struct arm64_stackframe {
|
||||
@@ -3626,8 +3614,6 @@ struct arm64_stackframe {
|
||||
machdep->machspec->last_p4d_read = (ulong)(P4D); \
|
||||
}
|
||||
|
||||
@ -1035,3 +1038,6 @@ index 95949507cae4..48f5e05e32f3 100644
|
||||
/*
|
||||
* PHYSICAL_PAGE_MASK changed (enlarged) between 2.4 and 2.6, so
|
||||
* for safety, use the 2.6 values to generate it.
|
||||
--
|
||||
2.17.1
|
||||
|
||||
|
35
SOURCES/rhel8_build.patch
Normal file
35
SOURCES/rhel8_build.patch
Normal file
@ -0,0 +1,35 @@
|
||||
diff --git crash-7.3.0/Makefile crash-7.3.0/Makefile
|
||||
index d0574d8f07d3..9dbb61d0dbc8 100644
|
||||
--- crash-7.3.0/Makefile
|
||||
+++ crash-7.3.0/Makefile
|
||||
@@ -198,7 +198,7 @@ GDB_FLAGS=
|
||||
# TARGET_CFLAGS will be configured automatically by configure
|
||||
TARGET_CFLAGS=
|
||||
|
||||
-CRASH_CFLAGS=-g -D${TARGET} ${TARGET_CFLAGS} ${GDB_FLAGS} ${CFLAGS}
|
||||
+CRASH_CFLAGS=-g -D${TARGET} ${TARGET_CFLAGS} ${GDB_FLAGS} ${CFLAGS} ${CPPFLAGS} -fPIE
|
||||
|
||||
GPL_FILES=
|
||||
TAR_FILES=${SOURCE_FILES} Makefile ${GPL_FILES} README .rh_rpm_package crash.8 \
|
||||
@@ -228,7 +228,7 @@ all: make_configure
|
||||
gdb_merge: force
|
||||
@if [ ! -f ${GDB}/README ]; then \
|
||||
make --no-print-directory gdb_unzip; fi
|
||||
- @echo "${LDFLAGS} -lz -llzo2 -lsnappy -ldl -rdynamic" > ${GDB}/gdb/mergelibs
|
||||
+ @echo "${LDFLAGS} -lz -llzo2 -lsnappy -ldl -rdynamic -Wl,-z,now -fpie" > ${GDB}/gdb/mergelibs
|
||||
@echo "../../${PROGRAM} ../../${PROGRAM}lib.a" > ${GDB}/gdb/mergeobj
|
||||
@rm -f ${PROGRAM}
|
||||
@if [ ! -f ${GDB}/config.status ]; then \
|
||||
diff --git crash-7.3.0/configure.c crash-7.3.0/configure.c
|
||||
index 75006e881f5a..06c94d58c56c 100644
|
||||
--- crash-7.3.0/configure.c
|
||||
+++ crash-7.3.0/configure.c
|
||||
@@ -780,7 +780,8 @@ build_configure(struct supported_gdb_version *sp)
|
||||
fprintf(fp2, "%s\n", sp->GDB);
|
||||
sprintf(target_data.gdb_version, "%s", &sp->GDB[4]);
|
||||
} else if (strncmp(buf, "LDFLAGS=", strlen("LDFLAGS=")) == 0) {
|
||||
- fprintf(fp2, "LDFLAGS=%s\n", ldflags ? ldflags : "");
|
||||
+ if (ldflags)
|
||||
+ fprintf(fp2, "LDFLAGS=%s\n", ldflags ? ldflags : "");
|
||||
} else
|
||||
fprintf(fp2, "%s", buf);
|
@ -3,7 +3,7 @@
|
||||
#
|
||||
Summary: Kernel analysis utility for live systems, netdump, diskdump, kdump, LKCD or mcore dumpfiles
|
||||
Name: crash
|
||||
Version: 7.2.9
|
||||
Version: 7.3.0
|
||||
Release: 2%{?dist}
|
||||
License: GPLv3
|
||||
Group: Development/Debuggers
|
||||
@ -72,6 +72,13 @@ rm -rf %{buildroot}
|
||||
%{_includedir}/*
|
||||
|
||||
%changelog
|
||||
* Fri May 14 2021 Lianbo Jiang <lijiang@redhat.com> - 7.3.0-2
|
||||
- Update the sha512 hash in the sources file to solve the
|
||||
compilation issues
|
||||
|
||||
* Thu May 13 2021 Lianbo Jiang <lijiang@redhat.com> - 7.3.0-1
|
||||
- Rebase to upstream 7.3.0
|
||||
|
||||
* Tue Dec 1 2020 Bhupesh Sharma <bhsharma@redhat.com> - 7.2.9-2
|
||||
- Fix the sources file to add gdb-7.6 tarball
|
||||
[The line was somehow removed when using rhpkg new-sources to
|
||||
|
Loading…
Reference in New Issue
Block a user