aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
Diffstat (limited to 'fs')
-rw-r--r--fs/ocfs2/xattr.c28
1 files changed, 14 insertions, 14 deletions
diff --git a/fs/ocfs2/xattr.c b/fs/ocfs2/xattr.c
index 123d378aba9e..3b059cf2eb45 100644
--- a/fs/ocfs2/xattr.c
+++ b/fs/ocfs2/xattr.c
@@ -636,8 +636,7 @@ leave:
636} 636}
637 637
638static int __ocfs2_remove_xattr_range(struct inode *inode, 638static int __ocfs2_remove_xattr_range(struct inode *inode,
639 struct buffer_head *root_bh, 639 struct ocfs2_xattr_value_buf *vb,
640 struct ocfs2_xattr_value_root *xv,
641 u32 cpos, u32 phys_cpos, u32 len, 640 u32 cpos, u32 phys_cpos, u32 len,
642 struct ocfs2_xattr_set_ctxt *ctxt) 641 struct ocfs2_xattr_set_ctxt *ctxt)
643{ 642{
@@ -645,16 +644,11 @@ static int __ocfs2_remove_xattr_range(struct inode *inode,
645 u64 phys_blkno = ocfs2_clusters_to_blocks(inode->i_sb, phys_cpos); 644 u64 phys_blkno = ocfs2_clusters_to_blocks(inode->i_sb, phys_cpos);
646 handle_t *handle = ctxt->handle; 645 handle_t *handle = ctxt->handle;
647 struct ocfs2_extent_tree et; 646 struct ocfs2_extent_tree et;
648 struct ocfs2_xattr_value_buf vb = {
649 .vb_bh = root_bh,
650 .vb_xv = xv,
651 .vb_access = ocfs2_journal_access,
652 };
653 647
654 ocfs2_init_xattr_value_extent_tree(&et, inode, &vb); 648 ocfs2_init_xattr_value_extent_tree(&et, inode, vb);
655 649
656 ret = vb.vb_access(handle, inode, vb.vb_bh, 650 ret = vb->vb_access(handle, inode, vb->vb_bh,
657 OCFS2_JOURNAL_ACCESS_WRITE); 651 OCFS2_JOURNAL_ACCESS_WRITE);
658 if (ret) { 652 if (ret) {
659 mlog_errno(ret); 653 mlog_errno(ret);
660 goto out; 654 goto out;
@@ -667,9 +661,9 @@ static int __ocfs2_remove_xattr_range(struct inode *inode,
667 goto out; 661 goto out;
668 } 662 }
669 663
670 le32_add_cpu(&vb.vb_xv->xr_clusters, -len); 664 le32_add_cpu(&vb->vb_xv->xr_clusters, -len);
671 665
672 ret = ocfs2_journal_dirty(handle, vb.vb_bh); 666 ret = ocfs2_journal_dirty(handle, vb->vb_bh);
673 if (ret) { 667 if (ret) {
674 mlog_errno(ret); 668 mlog_errno(ret);
675 goto out; 669 goto out;
@@ -693,6 +687,11 @@ static int ocfs2_xattr_shrink_size(struct inode *inode,
693 int ret = 0; 687 int ret = 0;
694 u32 trunc_len, cpos, phys_cpos, alloc_size; 688 u32 trunc_len, cpos, phys_cpos, alloc_size;
695 u64 block; 689 u64 block;
690 struct ocfs2_xattr_value_buf vb = {
691 .vb_bh = root_bh,
692 .vb_xv = xv,
693 .vb_access = ocfs2_journal_access,
694 };
696 695
697 if (old_clusters <= new_clusters) 696 if (old_clusters <= new_clusters)
698 return 0; 697 return 0;
@@ -701,7 +700,8 @@ static int ocfs2_xattr_shrink_size(struct inode *inode,
701 trunc_len = old_clusters - new_clusters; 700 trunc_len = old_clusters - new_clusters;
702 while (trunc_len) { 701 while (trunc_len) {
703 ret = ocfs2_xattr_get_clusters(inode, cpos, &phys_cpos, 702 ret = ocfs2_xattr_get_clusters(inode, cpos, &phys_cpos,
704 &alloc_size, &xv->xr_list); 703 &alloc_size,
704 &vb.vb_xv->xr_list);
705 if (ret) { 705 if (ret) {
706 mlog_errno(ret); 706 mlog_errno(ret);
707 goto out; 707 goto out;
@@ -710,7 +710,7 @@ static int ocfs2_xattr_shrink_size(struct inode *inode,
710 if (alloc_size > trunc_len) 710 if (alloc_size > trunc_len)
711 alloc_size = trunc_len; 711 alloc_size = trunc_len;
712 712
713 ret = __ocfs2_remove_xattr_range(inode, root_bh, xv, cpos, 713 ret = __ocfs2_remove_xattr_range(inode, &vb, cpos,
714 phys_cpos, alloc_size, 714 phys_cpos, alloc_size,
715 ctxt); 715 ctxt);
716 if (ret) { 716 if (ret) {