forked from Minki/linux
xfs: Add helper function xfs_attr_leaf_mark_incomplete
This patch helps to simplify xfs_attr_node_removename by modularizing the code around the transactions into helper functions. This will make the function easier to follow when we introduce delayed attributes. Signed-off-by: Allison Collins <allison.henderson@oracle.com> Reviewed-by: Amir Goldstein <amir73il@gmail.com> Reviewed-by: Chandan Rajendra <chandanrlinux@gmail.com> Reviewed-by: Brian Foster <bfoster@redhat.com> Reviewed-by: Darrick J. Wong <darrick.wong@oracle.com> Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com> Acked-by: Dave Chinner <dchinner@redhat.com>
This commit is contained in:
parent
db1a28cc59
commit
f44df68c82
@ -1131,6 +1131,32 @@ xfs_attr_node_shrink(
|
||||
return error;
|
||||
}
|
||||
|
||||
/*
|
||||
* Mark an attribute entry INCOMPLETE and save pointers to the relevant buffers
|
||||
* for later deletion of the entry.
|
||||
*/
|
||||
STATIC int
|
||||
xfs_attr_leaf_mark_incomplete(
|
||||
struct xfs_da_args *args,
|
||||
struct xfs_da_state *state)
|
||||
{
|
||||
int error;
|
||||
|
||||
/*
|
||||
* Fill in disk block numbers in the state structure
|
||||
* so that we can get the buffers back after we commit
|
||||
* several transactions in the following calls.
|
||||
*/
|
||||
error = xfs_attr_fillstate(state);
|
||||
if (error)
|
||||
return error;
|
||||
|
||||
/*
|
||||
* Mark the attribute as INCOMPLETE
|
||||
*/
|
||||
return xfs_attr3_leaf_setflag(args);
|
||||
}
|
||||
|
||||
/*
|
||||
* Remove a name from a B-tree attribute list.
|
||||
*
|
||||
@ -1162,20 +1188,7 @@ xfs_attr_node_removename(
|
||||
ASSERT(blk->bp != NULL);
|
||||
ASSERT(blk->magic == XFS_ATTR_LEAF_MAGIC);
|
||||
if (args->rmtblkno > 0) {
|
||||
/*
|
||||
* Fill in disk block numbers in the state structure
|
||||
* so that we can get the buffers back after we commit
|
||||
* several transactions in the following calls.
|
||||
*/
|
||||
error = xfs_attr_fillstate(state);
|
||||
if (error)
|
||||
goto out;
|
||||
|
||||
/*
|
||||
* Mark the attribute as INCOMPLETE, then bunmapi() the
|
||||
* remote value.
|
||||
*/
|
||||
error = xfs_attr3_leaf_setflag(args);
|
||||
error = xfs_attr_leaf_mark_incomplete(args, state);
|
||||
if (error)
|
||||
goto out;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user