[Crash-utility] EXT: RE: disk_dump_header status value

Agrain Patrick patrick.agrain at al-enterprise.com
Wed Mar 10 07:31:40 UTC 2021


Hello Kazu,

Thanks for the explanation. It's now clear.
I was mixing DISKDUMP_LOCAL and KDUMP_COMPRESSED_LOCAL dumpfiles.

Best regards,
Patrick Agrain

-----Message d'origine-----
De : HAGIO KAZUHITO(萩尾 一仁) [mailto:k-hagio-ab at nec.com] 
Envoyé : mercredi 10 mars 2021 02:52
À : Agrain Patrick <patrick.agrain at al-enterprise.com>
Cc : Discussion list for crash utility usage, maintenance and development <crash-utility at redhat.com>
Objet : EXT: RE: disk_dump_header status value


** External email - Please consider with caution **


-----Original Message-----
> Hello,
>
>
>
> I have a dump file produced by makedumpfile with following command:
>
>
>
> /sbin/makedumpfile -d 0 -c --message-level 7 /proc/vmcore 
> /tmpd/crashdump-`date +"%Y%m%d-%H%M"`
>
>
>
> When I edit the raw binary, it seems that the first bytes could be mapped to a disk_dump_header structure.
>
> Is that correct ?

Correct.

>
>
>
> When doing this, all seems to match: signature (KDUMP), header version (6), utsname content, timestamp.
>
> But not the status: I get 1 (INCOMPLETED), tough I’m able to analyze it with ‘crash’.
>
> I was expecting 0 or at least 8, because it should be zlib-compressed.

The INCOMPLETED status value you're saying is a diskdump one, makedumpfile doesn't use those values.  Please see "help -D"

crash> help -D
...
              status: 1 (DUMP_DH_COMPRESSED_ZLIB)

and crash's __diskdump_memory_dump():

        fprintf(fp, "              status: %x (", dh->status);
        switch (dd->flags & (DISKDUMP_LOCAL|KDUMP_CMPRS_LOCAL))
        {
        case DISKDUMP_LOCAL:
                if (dh->status == DUMP_HEADER_COMPLETED)
                        fprintf(fp, "DUMP_HEADER_COMPLETED");
                else if (dh->status == DUMP_HEADER_INCOMPLETED)
                        fprintf(fp, "DUMP_HEADER_INCOMPLETED");
                else if (dh->status == DUMP_HEADER_COMPRESSED)
                        fprintf(fp, "DUMP_HEADER_COMPRESSED");
                break;
        case KDUMP_CMPRS_LOCAL:
                if (dh->status & DUMP_DH_COMPRESSED_ZLIB)
                        fprintf(fp, "DUMP_DH_COMPRESSED_ZLIB");
                if (dh->status & DUMP_DH_COMPRESSED_LZO)
                        fprintf(fp, "DUMP_DH_COMPRESSED_LZO");
                if (dh->status & DUMP_DH_COMPRESSED_SNAPPY)
                        fprintf(fp, "DUMP_DH_COMPRESSED_SNAPPY");
                if (dh->status & DUMP_DH_COMPRESSED_INCOMPLETE)
                        fprintf(fp, "DUMP_DH_COMPRESSED_INCOMPLETE");
                if (dh->status & DUMP_DH_EXCLUDED_VMEMMAP)
                        fprintf(fp, "DUMP_DH_EXCLUDED_VMEMMAP");
                break;
        }

Thanks,
Kazu






More information about the Crash-utility mailing list