[PATCH] Get core dump code to work...
authorPetr Vandrovec <petr@vandrovec.name>
Fri, 13 Oct 2006 02:13:16 +0000 (04:13 +0200)
committerLinus Torvalds <torvalds@g5.osdl.org>
Fri, 13 Oct 2006 15:13:34 +0000 (08:13 -0700)
The file based core dump code was broken by pipe changes - a relative
llseek returns the absolute file position on success, not the relative
one, so dump_seek() always failed when invoked with non-zero current
position.

Only success/failure can be tested with relative lseek, we have to trust
kernel that on success we've got right file offset.  With this fix in
place I have finally real core files instead of 1KB fragments...

Signed-off-by: Petr Vandrovec <petr@vandrovec.name>
[ Cleaned it up a bit while here - use SEEK_CUR instead of hardcoding 1 ]
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
fs/binfmt_elf.c

index 06435f3665f472f7a1e7ff4879627bff3064c740..5610061279027df28a82c0448a086e7b90e7ed4c 100644 (file)
@@ -1152,7 +1152,7 @@ static int dump_write(struct file *file, const void *addr, int nr)
 static int dump_seek(struct file *file, loff_t off)
 {
        if (file->f_op->llseek && file->f_op->llseek != no_llseek) {
-               if (file->f_op->llseek(file, off, 1) != off)
+               if (file->f_op->llseek(file, off, SEEK_CUR) < 0)
                        return 0;
        } else {
                char *buf = (char *)get_zeroed_page(GFP_KERNEL);