diff options
Diffstat (limited to 'fs/ubifs')
-rw-r--r-- | fs/ubifs/io.c | 17 |
1 files changed, 8 insertions, 9 deletions
diff --git a/fs/ubifs/io.c b/fs/ubifs/io.c index 6cc09311a632..67bbde3550cf 100644 --- a/fs/ubifs/io.c +++ b/fs/ubifs/io.c | |||
@@ -573,7 +573,7 @@ out_timers: | |||
573 | int ubifs_wbuf_write_nolock(struct ubifs_wbuf *wbuf, void *buf, int len) | 573 | int ubifs_wbuf_write_nolock(struct ubifs_wbuf *wbuf, void *buf, int len) |
574 | { | 574 | { |
575 | struct ubifs_info *c = wbuf->c; | 575 | struct ubifs_info *c = wbuf->c; |
576 | int err, written, n, aligned_len = ALIGN(len, 8), offs; | 576 | int err, written, n, aligned_len = ALIGN(len, 8); |
577 | 577 | ||
578 | dbg_io("%d bytes (%s) to jhead %s wbuf at LEB %d:%d", len, | 578 | dbg_io("%d bytes (%s) to jhead %s wbuf at LEB %d:%d", len, |
579 | dbg_ntype(((struct ubifs_ch *)buf)->node_type), | 579 | dbg_ntype(((struct ubifs_ch *)buf)->node_type), |
@@ -636,7 +636,6 @@ int ubifs_wbuf_write_nolock(struct ubifs_wbuf *wbuf, void *buf, int len) | |||
636 | goto exit; | 636 | goto exit; |
637 | } | 637 | } |
638 | 638 | ||
639 | offs = wbuf->offs; | ||
640 | written = 0; | 639 | written = 0; |
641 | 640 | ||
642 | if (wbuf->used) { | 641 | if (wbuf->used) { |
@@ -653,7 +652,7 @@ int ubifs_wbuf_write_nolock(struct ubifs_wbuf *wbuf, void *buf, int len) | |||
653 | if (err) | 652 | if (err) |
654 | goto out; | 653 | goto out; |
655 | 654 | ||
656 | offs += wbuf->size; | 655 | wbuf->offs += wbuf->size; |
657 | len -= wbuf->avail; | 656 | len -= wbuf->avail; |
658 | aligned_len -= wbuf->avail; | 657 | aligned_len -= wbuf->avail; |
659 | written += wbuf->avail; | 658 | written += wbuf->avail; |
@@ -672,7 +671,7 @@ int ubifs_wbuf_write_nolock(struct ubifs_wbuf *wbuf, void *buf, int len) | |||
672 | if (err) | 671 | if (err) |
673 | goto out; | 672 | goto out; |
674 | 673 | ||
675 | offs += wbuf->size; | 674 | wbuf->offs += wbuf->size; |
676 | len -= wbuf->size; | 675 | len -= wbuf->size; |
677 | aligned_len -= wbuf->size; | 676 | aligned_len -= wbuf->size; |
678 | written += wbuf->size; | 677 | written += wbuf->size; |
@@ -687,12 +686,13 @@ int ubifs_wbuf_write_nolock(struct ubifs_wbuf *wbuf, void *buf, int len) | |||
687 | n = aligned_len >> c->max_write_shift; | 686 | n = aligned_len >> c->max_write_shift; |
688 | if (n) { | 687 | if (n) { |
689 | n <<= c->max_write_shift; | 688 | n <<= c->max_write_shift; |
690 | dbg_io("write %d bytes to LEB %d:%d", n, wbuf->lnum, offs); | 689 | dbg_io("write %d bytes to LEB %d:%d", n, wbuf->lnum, |
691 | err = ubi_leb_write(c->ubi, wbuf->lnum, buf + written, offs, n, | 690 | wbuf->offs); |
692 | wbuf->dtype); | 691 | err = ubi_leb_write(c->ubi, wbuf->lnum, buf + written, |
692 | wbuf->offs, n, wbuf->dtype); | ||
693 | if (err) | 693 | if (err) |
694 | goto out; | 694 | goto out; |
695 | offs += n; | 695 | wbuf->offs += n; |
696 | aligned_len -= n; | 696 | aligned_len -= n; |
697 | len -= n; | 697 | len -= n; |
698 | written += n; | 698 | written += n; |
@@ -707,7 +707,6 @@ int ubifs_wbuf_write_nolock(struct ubifs_wbuf *wbuf, void *buf, int len) | |||
707 | */ | 707 | */ |
708 | memcpy(wbuf->buf, buf + written, len); | 708 | memcpy(wbuf->buf, buf + written, len); |
709 | 709 | ||
710 | wbuf->offs = offs; | ||
711 | if (c->leb_size - wbuf->offs >= c->max_write_size) | 710 | if (c->leb_size - wbuf->offs >= c->max_write_size) |
712 | wbuf->size = c->max_write_size; | 711 | wbuf->size = c->max_write_size; |
713 | else | 712 | else |