|
@@ -328,13 +328,12 @@ xfs_attr_set(
|
|
|
*/
|
|
|
xfs_defer_init(args.dfops, args.firstblock);
|
|
|
error = xfs_attr_shortform_to_leaf(&args);
|
|
|
- if (!error)
|
|
|
- error = xfs_defer_finish(&args.trans, args.dfops, dp);
|
|
|
- if (error) {
|
|
|
- args.trans = NULL;
|
|
|
- xfs_defer_cancel(&dfops);
|
|
|
- goto out;
|
|
|
- }
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
+ xfs_defer_ijoin(args.dfops, dp);
|
|
|
+ error = xfs_defer_finish(&args.trans, args.dfops);
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
|
|
|
/*
|
|
|
* Commit the leaf transformation. We'll need another (linked)
|
|
@@ -373,6 +372,9 @@ xfs_attr_set(
|
|
|
|
|
|
return error;
|
|
|
|
|
|
+out_defer_cancel:
|
|
|
+ xfs_defer_cancel(&dfops);
|
|
|
+ args.trans = NULL;
|
|
|
out:
|
|
|
if (args.trans)
|
|
|
xfs_trans_cancel(args.trans);
|
|
@@ -593,13 +595,12 @@ xfs_attr_leaf_addname(xfs_da_args_t *args)
|
|
|
*/
|
|
|
xfs_defer_init(args->dfops, args->firstblock);
|
|
|
error = xfs_attr3_leaf_to_node(args);
|
|
|
- if (!error)
|
|
|
- error = xfs_defer_finish(&args->trans, args->dfops, dp);
|
|
|
- if (error) {
|
|
|
- args->trans = NULL;
|
|
|
- xfs_defer_cancel(args->dfops);
|
|
|
- return error;
|
|
|
- }
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
+ xfs_defer_ijoin(args->dfops, dp);
|
|
|
+ error = xfs_defer_finish(&args->trans, args->dfops);
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
|
|
|
/*
|
|
|
* Commit the current trans (including the inode) and start
|
|
@@ -684,14 +685,12 @@ xfs_attr_leaf_addname(xfs_da_args_t *args)
|
|
|
xfs_defer_init(args->dfops, args->firstblock);
|
|
|
error = xfs_attr3_leaf_to_shortform(bp, args, forkoff);
|
|
|
/* bp is gone due to xfs_da_shrink_inode */
|
|
|
- if (!error)
|
|
|
- error = xfs_defer_finish(&args->trans,
|
|
|
- args->dfops, dp);
|
|
|
- if (error) {
|
|
|
- args->trans = NULL;
|
|
|
- xfs_defer_cancel(args->dfops);
|
|
|
- return error;
|
|
|
- }
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
+ xfs_defer_ijoin(args->dfops, dp);
|
|
|
+ error = xfs_defer_finish(&args->trans, args->dfops);
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
}
|
|
|
|
|
|
/*
|
|
@@ -706,6 +705,10 @@ xfs_attr_leaf_addname(xfs_da_args_t *args)
|
|
|
error = xfs_attr3_leaf_clearflag(args);
|
|
|
}
|
|
|
return error;
|
|
|
+out_defer_cancel:
|
|
|
+ xfs_defer_cancel(args->dfops);
|
|
|
+ args->trans = NULL;
|
|
|
+ return error;
|
|
|
}
|
|
|
|
|
|
/*
|
|
@@ -747,15 +750,18 @@ xfs_attr_leaf_removename(xfs_da_args_t *args)
|
|
|
xfs_defer_init(args->dfops, args->firstblock);
|
|
|
error = xfs_attr3_leaf_to_shortform(bp, args, forkoff);
|
|
|
/* bp is gone due to xfs_da_shrink_inode */
|
|
|
- if (!error)
|
|
|
- error = xfs_defer_finish(&args->trans, args->dfops, dp);
|
|
|
- if (error) {
|
|
|
- args->trans = NULL;
|
|
|
- xfs_defer_cancel(args->dfops);
|
|
|
- return error;
|
|
|
- }
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
+ xfs_defer_ijoin(args->dfops, dp);
|
|
|
+ error = xfs_defer_finish(&args->trans, args->dfops);
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
}
|
|
|
return 0;
|
|
|
+out_defer_cancel:
|
|
|
+ xfs_defer_cancel(args->dfops);
|
|
|
+ args->trans = NULL;
|
|
|
+ return error;
|
|
|
}
|
|
|
|
|
|
/*
|
|
@@ -872,14 +878,12 @@ restart:
|
|
|
state = NULL;
|
|
|
xfs_defer_init(args->dfops, args->firstblock);
|
|
|
error = xfs_attr3_leaf_to_node(args);
|
|
|
- if (!error)
|
|
|
- error = xfs_defer_finish(&args->trans,
|
|
|
- args->dfops, dp);
|
|
|
- if (error) {
|
|
|
- args->trans = NULL;
|
|
|
- xfs_defer_cancel(args->dfops);
|
|
|
- goto out;
|
|
|
- }
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
+ xfs_defer_ijoin(args->dfops, dp);
|
|
|
+ error = xfs_defer_finish(&args->trans, args->dfops);
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
|
|
|
/*
|
|
|
* Commit the node conversion and start the next
|
|
@@ -900,13 +904,12 @@ restart:
|
|
|
*/
|
|
|
xfs_defer_init(args->dfops, args->firstblock);
|
|
|
error = xfs_da3_split(state);
|
|
|
- if (!error)
|
|
|
- error = xfs_defer_finish(&args->trans, args->dfops, dp);
|
|
|
- if (error) {
|
|
|
- args->trans = NULL;
|
|
|
- xfs_defer_cancel(args->dfops);
|
|
|
- goto out;
|
|
|
- }
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
+ xfs_defer_ijoin(args->dfops, dp);
|
|
|
+ error = xfs_defer_finish(&args->trans, args->dfops);
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
} else {
|
|
|
/*
|
|
|
* Addition succeeded, update Btree hashvals.
|
|
@@ -999,14 +1002,12 @@ restart:
|
|
|
if (retval && (state->path.active > 1)) {
|
|
|
xfs_defer_init(args->dfops, args->firstblock);
|
|
|
error = xfs_da3_join(state);
|
|
|
- if (!error)
|
|
|
- error = xfs_defer_finish(&args->trans,
|
|
|
- args->dfops, dp);
|
|
|
- if (error) {
|
|
|
- args->trans = NULL;
|
|
|
- xfs_defer_cancel(args->dfops);
|
|
|
- goto out;
|
|
|
- }
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
+ xfs_defer_ijoin(args->dfops, dp);
|
|
|
+ error = xfs_defer_finish(&args->trans, args->dfops);
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
}
|
|
|
|
|
|
/*
|
|
@@ -1032,6 +1033,10 @@ out:
|
|
|
if (error)
|
|
|
return error;
|
|
|
return retval;
|
|
|
+out_defer_cancel:
|
|
|
+ xfs_defer_cancel(args->dfops);
|
|
|
+ args->trans = NULL;
|
|
|
+ goto out;
|
|
|
}
|
|
|
|
|
|
/*
|
|
@@ -1122,13 +1127,12 @@ xfs_attr_node_removename(xfs_da_args_t *args)
|
|
|
if (retval && (state->path.active > 1)) {
|
|
|
xfs_defer_init(args->dfops, args->firstblock);
|
|
|
error = xfs_da3_join(state);
|
|
|
- if (!error)
|
|
|
- error = xfs_defer_finish(&args->trans, args->dfops, dp);
|
|
|
- if (error) {
|
|
|
- args->trans = NULL;
|
|
|
- xfs_defer_cancel(args->dfops);
|
|
|
- goto out;
|
|
|
- }
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
+ xfs_defer_ijoin(args->dfops, dp);
|
|
|
+ error = xfs_defer_finish(&args->trans, args->dfops);
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
/*
|
|
|
* Commit the Btree join operation and start a new trans.
|
|
|
*/
|
|
@@ -1156,14 +1160,12 @@ xfs_attr_node_removename(xfs_da_args_t *args)
|
|
|
xfs_defer_init(args->dfops, args->firstblock);
|
|
|
error = xfs_attr3_leaf_to_shortform(bp, args, forkoff);
|
|
|
/* bp is gone due to xfs_da_shrink_inode */
|
|
|
- if (!error)
|
|
|
- error = xfs_defer_finish(&args->trans,
|
|
|
- args->dfops, dp);
|
|
|
- if (error) {
|
|
|
- args->trans = NULL;
|
|
|
- xfs_defer_cancel(args->dfops);
|
|
|
- goto out;
|
|
|
- }
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
+ xfs_defer_ijoin(args->dfops, dp);
|
|
|
+ error = xfs_defer_finish(&args->trans, args->dfops);
|
|
|
+ if (error)
|
|
|
+ goto out_defer_cancel;
|
|
|
} else
|
|
|
xfs_trans_brelse(args->trans, bp);
|
|
|
}
|
|
@@ -1172,6 +1174,10 @@ xfs_attr_node_removename(xfs_da_args_t *args)
|
|
|
out:
|
|
|
xfs_da_state_free(state);
|
|
|
return error;
|
|
|
+out_defer_cancel:
|
|
|
+ xfs_defer_cancel(args->dfops);
|
|
|
+ args->trans = NULL;
|
|
|
+ goto out;
|
|
|
}
|
|
|
|
|
|
/*
|