diff options
author | Dave Chinner <dchinner@redhat.com> | 2013-06-03 01:28:49 -0400 |
---|---|---|
committer | Ben Myers <bpm@sgi.com> | 2013-06-04 18:36:30 -0400 |
commit | 59913f14dfe8eb772ff93eb442947451b4416329 (patch) | |
tree | a9925823147b4a3be6f5bc6086750b1acf7a3af6 /fs/xfs | |
parent | 6fcdc59de28817d1fbf1bd58cc01f4f3fac858fb (diff) |
xfs: fix remote attribute invalidation for a leaf
When invalidating an attribute leaf block block, there might be
remote attributes that it points to. With the recent rework of the
remote attribute format, we have to make sure we calculate the
length of the attribute correctly. We aren't doing that in
xfs_attr3_leaf_inactive(), so fix it.
Signed-off-by: Dave Chinner <dchinner@redhat.com>
Reviewed-by: Brian Foster <bfoster@redhat.com>
Reviewed-by: Mark Tinguely <tinuguely@sgi.com>
Signed-off-by: Ben Myers <bpm@sgi.com>
Diffstat (limited to 'fs/xfs')
-rw-r--r-- | fs/xfs/xfs_attr_leaf.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/xfs/xfs_attr_leaf.c b/fs/xfs/xfs_attr_leaf.c index d788302e506a..31d3cd129269 100644 --- a/fs/xfs/xfs_attr_leaf.c +++ b/fs/xfs/xfs_attr_leaf.c | |||
@@ -3258,7 +3258,7 @@ xfs_attr3_leaf_inactive( | |||
3258 | name_rmt = xfs_attr3_leaf_name_remote(leaf, i); | 3258 | name_rmt = xfs_attr3_leaf_name_remote(leaf, i); |
3259 | if (name_rmt->valueblk) { | 3259 | if (name_rmt->valueblk) { |
3260 | lp->valueblk = be32_to_cpu(name_rmt->valueblk); | 3260 | lp->valueblk = be32_to_cpu(name_rmt->valueblk); |
3261 | lp->valuelen = XFS_B_TO_FSB(dp->i_mount, | 3261 | lp->valuelen = xfs_attr3_rmt_blocks(dp->i_mount, |
3262 | be32_to_cpu(name_rmt->valuelen)); | 3262 | be32_to_cpu(name_rmt->valuelen)); |
3263 | lp++; | 3263 | lp++; |
3264 | } | 3264 | } |