@@ -55,8 +55,8 @@ CFILES = cache.c \
buf_item.c \
defer_item.c \
init.c \
+ inode_item.c \
kmem.c \
- logitem.c \
rdwr.c \
trans.c \
trans_buf.c \
new file mode 100644
@@ -0,0 +1,117 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
+ * All Rights Reserved.
+ */
+
+#include "libxfs_priv.h"
+#include "xfs_fs.h"
+#include "xfs_shared.h"
+#include "xfs_format.h"
+#include "xfs_log_format.h"
+#include "xfs_trans_resv.h"
+#include "xfs_mount.h"
+#include "xfs_inode_buf.h"
+#include "xfs_inode_fork.h"
+#include "xfs_inode.h"
+#include "xfs_trans.h"
+
+kmem_zone_t *xfs_ili_zone; /* inode log item zone */
+
+/*
+ * Initialize the inode log item for a newly allocated (in-core) inode.
+ */
+void
+xfs_inode_item_init(
+ xfs_inode_t *ip,
+ xfs_mount_t *mp)
+{
+ xfs_inode_log_item_t *iip;
+
+ ASSERT(ip->i_itemp == NULL);
+ iip = ip->i_itemp = (xfs_inode_log_item_t *)
+ kmem_zone_zalloc(xfs_ili_zone, KM_SLEEP);
+#ifdef LI_DEBUG
+ fprintf(stderr, "inode_item_init for inode %llu, iip=%p\n",
+ ip->i_ino, iip);
+#endif
+
+ iip->ili_item.li_type = XFS_LI_INODE;
+ iip->ili_item.li_mountp = mp;
+ INIT_LIST_HEAD(&iip->ili_item.li_trans);
+ iip->ili_inode = ip;
+}
+
+static void
+xfs_inode_item_put(
+ struct xfs_inode_log_item *iip)
+{
+ struct xfs_inode *ip = iip->ili_inode;
+
+ ip->i_itemp = NULL;
+ kmem_zone_free(xfs_ili_zone, iip);
+}
+
+/*
+ * Transaction commital code follows (i.e. write to disk in libxfs)
+ *
+ * XXX (dgc): should failure to flush the inode (e.g. due to uncorrected
+ * corruption) result in transaction commit failure w/ EFSCORRUPTED?
+ */
+void
+inode_item_done(
+ xfs_inode_log_item_t *iip)
+{
+ xfs_dinode_t *dip;
+ xfs_inode_t *ip;
+ xfs_mount_t *mp;
+ xfs_buf_t *bp;
+ int error;
+
+ ip = iip->ili_inode;
+ mp = iip->ili_item.li_mountp;
+ ASSERT(ip != NULL);
+
+ if (!(iip->ili_fields & XFS_ILOG_ALL))
+ goto free;
+
+ /*
+ * Get the buffer containing the on-disk inode.
+ */
+ error = xfs_imap_to_bp(mp, NULL, &ip->i_imap, &dip, &bp, 0, 0);
+ if (error) {
+ fprintf(stderr, _("%s: warning - imap_to_bp failed (%d)\n"),
+ progname, error);
+ goto free;
+ }
+
+ /*
+ * Flush the inode and disassociate it from the transaction regardless
+ * of whether the flush succeed or not. If we fail the flush, make sure
+ * we still release the buffer reference we currently hold.
+ */
+ error = libxfs_iflush_int(ip, bp);
+ bp->b_transp = NULL; /* remove xact ptr */
+
+ if (error) {
+ fprintf(stderr, _("%s: warning - iflush_int failed (%d)\n"),
+ progname, error);
+ libxfs_putbuf(bp);
+ goto free;
+ }
+
+ libxfs_writebuf(bp, 0);
+#ifdef XACT_DEBUG
+ fprintf(stderr, "flushing dirty inode %llu, buffer %p\n",
+ ip->i_ino, bp);
+#endif
+free:
+ xfs_inode_item_put(iip);
+}
+
+void
+inode_item_unlock(
+ xfs_inode_log_item_t *iip)
+{
+ xfs_inode_item_put(iip);
+}
@@ -491,6 +491,7 @@ struct xfs_log_item;
struct xfs_buf;
struct xfs_buf_map;
struct xfs_buf_log_item;
+struct xfs_inode_log_item;
struct xfs_buftarg;
/* xfs_attr.c */
@@ -515,6 +516,8 @@ void xfs_trans_del_item(struct xfs_log_item *);
/* xfs_inode_item.c */
void xfs_inode_item_init(struct xfs_inode *, struct xfs_mount *);
+void inode_item_done(struct xfs_inode_log_item *iip);
+void inode_item_unlock(struct xfs_inode_log_item *iip);
/* xfs_buf_item.c */
void xfs_buf_item_init(struct xfs_buf *, struct xfs_mount *);
deleted file mode 100644
@@ -1,43 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0
-/*
- * Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
- * All Rights Reserved.
- */
-
-#include "libxfs_priv.h"
-#include "xfs_fs.h"
-#include "xfs_shared.h"
-#include "xfs_format.h"
-#include "xfs_log_format.h"
-#include "xfs_trans_resv.h"
-#include "xfs_mount.h"
-#include "xfs_inode_buf.h"
-#include "xfs_inode_fork.h"
-#include "xfs_inode.h"
-#include "xfs_trans.h"
-
-kmem_zone_t *xfs_ili_zone; /* inode log item zone */
-
-/*
- * Initialize the inode log item for a newly allocated (in-core) inode.
- */
-void
-xfs_inode_item_init(
- xfs_inode_t *ip,
- xfs_mount_t *mp)
-{
- xfs_inode_log_item_t *iip;
-
- ASSERT(ip->i_itemp == NULL);
- iip = ip->i_itemp = (xfs_inode_log_item_t *)
- kmem_zone_zalloc(xfs_ili_zone, KM_SLEEP);
-#ifdef LI_DEBUG
- fprintf(stderr, "inode_item_init for inode %llu, iip=%p\n",
- ip->i_ino, iip);
-#endif
-
- iip->ili_item.li_type = XFS_LI_INODE;
- iip->ili_item.li_mountp = mp;
- INIT_LIST_HEAD(&iip->ili_item.li_trans);
- iip->ili_inode = ip;
-}
@@ -470,74 +470,6 @@ _("Transaction block reservation exceeded! %u > %u\n"),
}
static void
-xfs_inode_item_put(
- struct xfs_inode_log_item *iip)
-{
- struct xfs_inode *ip = iip->ili_inode;
-
- ip->i_itemp = NULL;
- kmem_zone_free(xfs_ili_zone, iip);
-}
-
-
-/*
- * Transaction commital code follows (i.e. write to disk in libxfs)
- *
- * XXX (dgc): should failure to flush the inode (e.g. due to uncorrected
- * corruption) result in transaction commit failure w/ EFSCORRUPTED?
- */
-static void
-inode_item_done(
- xfs_inode_log_item_t *iip)
-{
- xfs_dinode_t *dip;
- xfs_inode_t *ip;
- xfs_mount_t *mp;
- xfs_buf_t *bp;
- int error;
-
- ip = iip->ili_inode;
- mp = iip->ili_item.li_mountp;
- ASSERT(ip != NULL);
-
- if (!(iip->ili_fields & XFS_ILOG_ALL))
- goto free;
-
- /*
- * Get the buffer containing the on-disk inode.
- */
- error = xfs_imap_to_bp(mp, NULL, &ip->i_imap, &dip, &bp, 0, 0);
- if (error) {
- fprintf(stderr, _("%s: warning - imap_to_bp failed (%d)\n"),
- progname, error);
- goto free;
- }
-
- /*
- * Flush the inode and disassociate it from the transaction regardless
- * of whether the flush succeed or not. If we fail the flush, make sure
- * we still release the buffer reference we currently hold.
- */
- error = libxfs_iflush_int(ip, bp);
- bp->b_transp = NULL; /* remove xact ptr */
-
- if (error) {
- fprintf(stderr, _("%s: warning - iflush_int failed (%d)\n"),
- progname, error);
- libxfs_putbuf(bp);
- goto free;
- }
-
- libxfs_writebuf(bp, 0);
-#ifdef XACT_DEBUG
- fprintf(stderr, "flushing dirty inode %llu, buffer %p\n",
- ip->i_ino, bp);
-#endif
-free:
- xfs_inode_item_put(iip);
-}
-
-static void
trans_committed(
xfs_trans_t *tp)
{
@@ -558,13 +490,6 @@ trans_committed(
}
}
-static void
-inode_item_unlock(
- xfs_inode_log_item_t *iip)
-{
- xfs_inode_item_put(iip);
-}
-
/* Detach and unlock all of the items in a transaction */
static void
xfs_trans_free_items(
Pull functions out of libxfs/* into inode_item.c, if they roughly match the kernel's xfs_inode_item.c file. Signed-off-by: Eric Sandeen <sandeen@redhat.com> --- libxfs/Makefile | 2 +- libxfs/inode_item.c | 117 +++++++++++++++++++++++++++++++++++++++++++++++++++ libxfs/libxfs_priv.h | 3 ++ libxfs/logitem.c | 43 ------------------- libxfs/trans.c | 75 --------------------------------- 5 files changed, 121 insertions(+), 119 deletions(-) create mode 100644 libxfs/inode_item.c delete mode 100644 libxfs/logitem.c