mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-12-11 16:00:50 -07:00
target-i386: add API to get dump info
Dump info contains: endian, class and architecture. The next patch will use these information to create vmcore. Note: on x86 box, the class is ELFCLASS64 if the memory is larger than 4G. Signed-off-by: Wen Congyang <wency@cn.fujitsu.com> Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com>
This commit is contained in:
parent
90166b71c4
commit
25ae9c1d8b
3 changed files with 64 additions and 0 deletions
|
|
@ -13,6 +13,7 @@
|
|||
|
||||
#include "cpu.h"
|
||||
#include "cpu-all.h"
|
||||
#include "dump.h"
|
||||
#include "elf.h"
|
||||
|
||||
#ifdef TARGET_X86_64
|
||||
|
|
@ -380,3 +381,36 @@ int cpu_write_elf32_qemunote(write_core_dump_function f, CPUArchState *env,
|
|||
{
|
||||
return cpu_write_qemu_note(f, env, opaque, 0);
|
||||
}
|
||||
|
||||
int cpu_get_dump_info(ArchDumpInfo *info)
|
||||
{
|
||||
bool lma = false;
|
||||
RAMBlock *block;
|
||||
|
||||
#ifdef TARGET_X86_64
|
||||
lma = !!(first_cpu->hflags & HF_LMA_MASK);
|
||||
#endif
|
||||
|
||||
if (lma) {
|
||||
info->d_machine = EM_X86_64;
|
||||
} else {
|
||||
info->d_machine = EM_386;
|
||||
}
|
||||
info->d_endian = ELFDATA2LSB;
|
||||
|
||||
if (lma) {
|
||||
info->d_class = ELFCLASS64;
|
||||
} else {
|
||||
info->d_class = ELFCLASS32;
|
||||
|
||||
QLIST_FOREACH(block, &ram_list.blocks, next) {
|
||||
if (block->offset + block->length > UINT_MAX) {
|
||||
/* The memory size is greater than 4G */
|
||||
info->d_class = ELFCLASS64;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue