forked from crash-utility/crash
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnetdump.h
154 lines (137 loc) · 3.42 KB
/
netdump.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
/* netdump.h
*
* Copyright (C) 2002-2009, 2017-2018 David Anderson
* Copyright (C) 2002-2009, 2017-2018 Red Hat, Inc. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* Author: David Anderson
*/
#include <elf.h>
#include "vmcore.h"
#define MIN_NETDUMP_ELF32_HEADER_SIZE \
sizeof(Elf32_Ehdr)+sizeof(Elf32_Phdr)+sizeof(Elf32_Phdr)
#define MIN_NETDUMP_ELF64_HEADER_SIZE \
sizeof(Elf64_Ehdr)+sizeof(Elf64_Phdr)+sizeof(Elf64_Phdr)
#define MIN_NETDUMP_ELF_HEADER_SIZE \
MAX(MIN_NETDUMP_ELF32_HEADER_SIZE, MIN_NETDUMP_ELF64_HEADER_SIZE)
#define NT_TASKSTRUCT 4
#define NT_DISKDUMP 0x70000001
#ifdef NOTDEF
/*
* Note: Based upon the original, abandoned, proposal for
* its contents -- keep around for potential future use.
*/
#ifndef NT_KDUMPINFO
#define NT_KDUMPINFO 7
#endif
#endif /* NOTDEF */
struct pt_load_segment {
off_t file_offset;
physaddr_t phys_start;
physaddr_t phys_end;
physaddr_t zero_fill;
};
struct vmcore_data {
ulong flags;
int ndfd;
FILE *ofp;
uint header_size;
char *elf_header;
uint num_pt_load_segments;
struct pt_load_segment *pt_load_segments;
Elf32_Ehdr *elf32;
Elf32_Phdr *notes32;
Elf32_Phdr *load32;
Elf64_Ehdr *elf64;
Elf64_Phdr *notes64;
Elf64_Phdr *load64;
Elf64_Shdr *sect0_64;
void *nt_prstatus;
void *nt_prpsinfo;
void *nt_taskstruct;
ulong task_struct;
uint page_size;
ulong switch_stack;
uint num_prstatus_notes;
void *nt_prstatus_percpu[NR_CPUS];
void *vmcoreinfo;
uint size_vmcoreinfo;
/* Backup Region, first 640K of System RAM. */
#define KEXEC_BACKUP_SRC_END 0x0009ffff
uint num_qemu_notes;
void *nt_qemu_percpu[NR_CPUS];
ulonglong backup_src_start;
ulong backup_src_size;
ulonglong backup_offset;
ulong arch_data;
#define arch_data1 arch_data
ulong phys_base;
ulong arch_data2;
void *nt_vmcoredd_array[NR_DEVICE_DUMPS];
uint num_vmcoredd_notes;
};
#define DUMP_ELF_INCOMPLETE 0x1 /* dumpfile is incomplete */
/*
* S390 CPU timer ELF note
*/
#ifndef NT_S390_TIMER
#define NT_S390_TIMER 0x301
#endif
/*
* S390 TOD clock comparator ELF note
*/
#ifndef NT_S390_TODCMP
#define NT_S390_TODCMP 0x302
#endif
/*
* S390 TOD programmable register ELF note
*/
#ifndef NT_S390_TODPREG
#define NT_S390_TODPREG 0x303
#endif
/*
* S390 control registers ELF note
*/
#ifndef NT_S390_CTRS
#define NT_S390_CTRS 0x304
#endif
/*
* S390 prefix ELF note
*/
#ifndef NT_S390_PREFIX
#define NT_S390_PREFIX 0x305
#endif
/*
* S390 vector registers 0-15 upper half note (16 * u64)
*/
#ifndef NT_S390_VXRS_LOW
#define NT_S390_VXRS_LOW 0x309
#endif
/*
* S390 vector registers 16-31 note (16 * u128)
*/
#ifndef NT_S390_VXRS_HIGH
#define NT_S390_VXRS_HIGH 0x30a
#endif
#define MAX_KCORE_ELF_HEADER_SIZE (32768)
struct proc_kcore_data {
uint flags;
uint segments;
char *elf_header;
size_t header_size;
Elf64_Phdr *load64;
Elf64_Phdr *notes64;
Elf32_Phdr *load32;
Elf32_Phdr *notes32;
void *vmcoreinfo;
uint size_vmcoreinfo;
};