On Wed, Aug 03, 2016 at 09:55:07PM +0200, Laurent Vivier wrote: > If we don't provide the page size in target-ppc:cpu_get_dump_info(), > the default one (TARGET_PAGE_SIZE, 4KB) is used to create > the compressed dump. It works fine with Macintosh, but not with > pseries as the kernel default page size is 64KB. > > Without this patch, if we generate a compressed dump in the QEMU monitor: > > (qemu) dump-guest-memory -z qemu.dump > > This dump cannot be read by crash: > > # crash vmlinux qemu.dump > ... > WARNING: cannot translate vmemmap kernel virtual addresses: > commands requiring page structure contents will fail > ... > > Signed-off-by: Laurent Vivier <lviv...@redhat.com> > --- > target-ppc/arch_dump.c | 5 +++++ > 1 file changed, 5 insertions(+) > > diff --git a/target-ppc/arch_dump.c b/target-ppc/arch_dump.c > index df1fd8c..ad37a59 100644 > --- a/target-ppc/arch_dump.c > +++ b/target-ppc/arch_dump.c > @@ -220,6 +220,11 @@ int cpu_get_dump_info(ArchDumpInfo *info, > } else { > info->d_endian = ELFDATA2LSB; > } > + /* 64KB is the page size default for pseries kernel */
This comment should rather say '...is the max page size...' than 'default' to be accurate for the reasoning. I have a comment like that in the arm version, info->page_size = (1 << 16); /* aarch64 max pagesize */ > + if (strncmp(object_get_typename(qdev_get_machine()), > + "pseries-", 8) == 0) { > + info->page_size = (1U << 16); > + } > > return 0; > } > -- > 2.5.5 > > Otherwise, Reviewed-by: Andrew Jones <drjo...@redhat.com>