[Crash-utility] A patch for match_file_string()
Dave Anderson
anderson at redhat.com
Thu Mar 13 21:23:58 UTC 2008
Alex Sidorenko wrote:
> Hi Dave,
>
> on some distributions (e.g. Ubuntu) crash cannot find the live kernel image
> because of a slight mismatch between kt->proc_version and 'strings' output
> from namelist file (e.g. /boot/vmlinux-debug-2.6.22-14-generic)
>
> Namely, kt->proc_version is LF-terminated, but there is no LF in 'strings
> vmlinux' output.
>
> If I strip LF from the end of kt->proc_version, everything works fine
>
> --- filesys.c.orig 2008-02-28 11:09:10.000000000 -0500
> +++ filesys.c 2008-03-13 16:33:02.000000000 -0400
> @@ -3689,7 +3689,10 @@
> int found;
> char command[BUFSIZE];
> FILE *pipe;
> + int slen = strlen(string);
>
> + if (slen && string[slen-1] == '\n')
> + string[slen-1] = '\0';
>
> sprintf(command, "/usr/bin/strings %s", filename);
> if ((pipe = popen(command, "r")) == NULL) {
>
> =====================================================================
>
> Regards,
> Alex
>
>
Hi Alex,
Help me out here -- when I run it, both kt->proc_version and the buffer
read from the strings output read by fgets() both have linefeeds.
Are you saying that the fgets() call is stripping the linefeed from
the strings output? The "strings vmlinux" output has to have linefeeds
or else it would be a huge mash of characters.
What am I missing?
Dave
More information about the Crash-utility
mailing list