X-Git-Url: https://git.kernelconcepts.de/?a=blobdiff_plain;f=fs%2Fcoredump.c;h=281b768000e664e4d4ef9092d4bb567d003623a0;hb=f913a72aa008777d4a92f82acafb17cce9aed4dc;hp=38a7ab87e10a80d9d62d80b74dd58c1f2989a966;hpb=03cce00b4b0d70885c7a63ef17713b8cc2b1c8bd;p=karo-tx-linux.git diff --git a/fs/coredump.c b/fs/coredump.c index 38a7ab87e10a..281b768000e6 100644 --- a/fs/coredump.c +++ b/fs/coredump.c @@ -794,6 +794,7 @@ int dump_emit(struct coredump_params *cprm, const void *addr, int nr) return 0; file->f_pos = pos; cprm->written += n; + cprm->pos += n; nr -= n; } return 1; @@ -808,6 +809,7 @@ int dump_skip(struct coredump_params *cprm, size_t nr) if (dump_interrupted() || file->f_op->llseek(file, nr, SEEK_CUR) < 0) return 0; + cprm->pos += nr; return 1; } else { while (nr > PAGE_SIZE) { @@ -822,7 +824,7 @@ EXPORT_SYMBOL(dump_skip); int dump_align(struct coredump_params *cprm, int align) { - unsigned mod = cprm->file->f_pos & (align - 1); + unsigned mod = cprm->pos & (align - 1); if (align & (align - 1)) return 0; return mod ? dump_skip(cprm, align - mod) : 1;