xfs: turn dfp_done into a xfs_log_item
All defer op instance place their own extension of the log item into the dfp_done field. Replace that with a xfs_log_item to improve type safety and make the code easier to follow. Also use the opportunity to improve the ->finish_item calling conventions to place the done log item as the higher level structure before the list_entry used for the individual items. Signed-off-by: Christoph Hellwig <hch@lst.de> 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>
This commit is contained in:

committed by
Darrick J. Wong

parent
bb47d79750
commit
f09d167c20
@@ -371,7 +371,7 @@ xfs_defer_finish_one(
|
||||
list_for_each_safe(li, n, &dfp->dfp_work) {
|
||||
list_del(li);
|
||||
dfp->dfp_count--;
|
||||
error = ops->finish_item(tp, li, dfp->dfp_done, &state);
|
||||
error = ops->finish_item(tp, dfp->dfp_done, li, &state);
|
||||
if (error == -EAGAIN) {
|
||||
/*
|
||||
* Caller wants a fresh transaction; put the work item
|
||||
|
@@ -29,7 +29,7 @@ struct xfs_defer_pending {
|
||||
struct list_head dfp_list; /* pending items */
|
||||
struct list_head dfp_work; /* work items */
|
||||
struct xfs_log_item *dfp_intent; /* log intent item */
|
||||
void *dfp_done; /* log done item */
|
||||
struct xfs_log_item *dfp_done; /* log done item */
|
||||
unsigned int dfp_count; /* # extent items */
|
||||
enum xfs_defer_ops_type dfp_type;
|
||||
};
|
||||
@@ -46,10 +46,10 @@ struct xfs_defer_op_type {
|
||||
struct xfs_log_item *(*create_intent)(struct xfs_trans *tp,
|
||||
struct list_head *items, unsigned int count, bool sort);
|
||||
void (*abort_intent)(struct xfs_log_item *intent);
|
||||
void *(*create_done)(struct xfs_trans *tp, struct xfs_log_item *intent,
|
||||
unsigned int count);
|
||||
int (*finish_item)(struct xfs_trans *, struct list_head *, void *,
|
||||
void **);
|
||||
struct xfs_log_item *(*create_done)(struct xfs_trans *tp,
|
||||
struct xfs_log_item *intent, unsigned int count);
|
||||
int (*finish_item)(struct xfs_trans *tp, struct xfs_log_item *done,
|
||||
struct list_head *item, void **state);
|
||||
void (*finish_cleanup)(struct xfs_trans *, void *, int);
|
||||
void (*cancel_item)(struct list_head *);
|
||||
unsigned int max_items;
|
||||
|
Reference in New Issue
Block a user