From: allison.henderson@oracle.com
To: linux-xfs@vger.kernel.org
Subject: [PATCH v6 00/27] Parent Pointers
Date: Tue, 29 Nov 2022 14:12:15 -0700 [thread overview]
Message-ID: <20221129211242.2689855-1-allison.henderson@oracle.com> (raw)
From: Allison Henderson <allison.henderson@oracle.com>
Hi all,
This is the latest parent pointer attributes for xfs.
The goal of this patch set is to add a parent pointer attribute to each inode.
The attribute name containing the parent inode, generation, and directory
offset, while the attribute value contains the file name. This feature will
enable future optimizations for online scrub, or any other feature that could
make use of quickly deriving an inodes path from the mount point.
This set can be viewed on github here
https://github.com/allisonhenderson/xfs/tree/xfs_new_pptrsv6
And the corresponding xfsprogs code is here
https://github.com/allisonhenderson/xfsprogs/tree/xfsprogs_new_pptrs_v6
This set has been tested with the below parent pointers tests
https://lore.kernel.org/fstests/20221012013812.82161-1-catherine.hoang@oracle.com/T/#t
Updates since v5:
xfs: Increase XFS_QM_TRANS_MAXDQS to 5
NEW
xfs: parent pointer attribute creation
Declare xfs_create_space_res, xfs_mkdir_space_res static
xfs: add parent attributes to link
Declare xfs_link_space_res static
xfs: add parent attributes to symlink
Declare xfs_symlink_space_res static
xfs: remove parent pointers in unlink
Declare xfs_remove_space_res static
xfs: Add parent pointers to rename
Declare xfs_rename_space_res static
xfs: Add parent pointer ioctl
Added out_unlock goto
Questions comments and feedback appreciated!
Thanks all!
Allison
Allison Henderson (27):
xfs: Add new name to attri/d
xfs: Increase XFS_DEFER_OPS_NR_INODES to 5
xfs: Increase XFS_QM_TRANS_MAXDQS to 5
xfs: Hold inode locks in xfs_ialloc
xfs: Hold inode locks in xfs_trans_alloc_dir
xfs: Hold inode locks in xfs_rename
xfs: Expose init_xattrs in xfs_create_tmpfile
xfs: get directory offset when adding directory name
xfs: get directory offset when removing directory name
xfs: get directory offset when replacing a directory name
xfs: add parent pointer support to attribute code
xfs: define parent pointer xattr format
xfs: Add xfs_verify_pptr
xfs: extend transaction reservations for parent attributes
xfs: parent pointer attribute creation
xfs: add parent attributes to link
xfs: add parent attributes to symlink
xfs: remove parent pointers in unlink
xfs: Indent xfs_rename
xfs: Add parent pointers to rename
xfs: Add parent pointers to xfs_cross_rename
xfs: Add the parent pointer support to the superblock version 5.
xfs: Add helper function xfs_attr_list_context_init
xfs: Filter XFS_ATTR_PARENT for getfattr
xfs: Add parent pointer ioctl
xfs: fix unit conversion error in xfs_log_calc_max_attrsetm_res
xfs: drop compatibility minimum log size computations for reflink
fs/xfs/Makefile | 2 +
fs/xfs/libxfs/xfs_attr.c | 71 +++++-
fs/xfs/libxfs/xfs_attr.h | 13 +-
fs/xfs/libxfs/xfs_da_btree.h | 3 +
fs/xfs/libxfs/xfs_da_format.h | 38 ++-
fs/xfs/libxfs/xfs_defer.c | 28 ++-
fs/xfs/libxfs/xfs_defer.h | 8 +-
fs/xfs/libxfs/xfs_dir2.c | 21 +-
fs/xfs/libxfs/xfs_dir2.h | 7 +-
fs/xfs/libxfs/xfs_dir2_block.c | 9 +-
fs/xfs/libxfs/xfs_dir2_leaf.c | 8 +-
fs/xfs/libxfs/xfs_dir2_node.c | 8 +-
fs/xfs/libxfs/xfs_dir2_sf.c | 6 +
fs/xfs/libxfs/xfs_format.h | 4 +-
fs/xfs/libxfs/xfs_fs.h | 75 ++++++
fs/xfs/libxfs/xfs_log_format.h | 7 +-
fs/xfs/libxfs/xfs_log_rlimit.c | 53 ++++
fs/xfs/libxfs/xfs_parent.c | 207 ++++++++++++++++
fs/xfs/libxfs/xfs_parent.h | 46 ++++
fs/xfs/libxfs/xfs_sb.c | 4 +
fs/xfs/libxfs/xfs_trans_resv.c | 324 ++++++++++++++++++++----
fs/xfs/libxfs/xfs_trans_space.h | 8 -
fs/xfs/scrub/attr.c | 2 +-
fs/xfs/xfs_attr_item.c | 142 +++++++++--
fs/xfs/xfs_attr_item.h | 1 +
fs/xfs/xfs_attr_list.c | 17 +-
fs/xfs/xfs_dquot.c | 25 ++
fs/xfs/xfs_dquot.h | 1 +
fs/xfs/xfs_file.c | 1 +
fs/xfs/xfs_inode.c | 424 +++++++++++++++++++++++++-------
fs/xfs/xfs_inode.h | 3 +-
fs/xfs/xfs_ioctl.c | 148 +++++++++--
fs/xfs/xfs_ioctl.h | 2 +
fs/xfs/xfs_iops.c | 3 +-
fs/xfs/xfs_ondisk.h | 4 +
fs/xfs/xfs_parent_utils.c | 125 ++++++++++
fs/xfs/xfs_parent_utils.h | 11 +
fs/xfs/xfs_qm.c | 4 +-
fs/xfs/xfs_qm.h | 2 +-
fs/xfs/xfs_super.c | 4 +
fs/xfs/xfs_symlink.c | 54 +++-
fs/xfs/xfs_trans.c | 6 +-
fs/xfs/xfs_trans_dquot.c | 15 +-
fs/xfs/xfs_xattr.c | 5 +-
fs/xfs/xfs_xattr.h | 1 +
45 files changed, 1708 insertions(+), 242 deletions(-)
create mode 100644 fs/xfs/libxfs/xfs_parent.c
create mode 100644 fs/xfs/libxfs/xfs_parent.h
create mode 100644 fs/xfs/xfs_parent_utils.c
create mode 100644 fs/xfs/xfs_parent_utils.h
--
2.25.1
next reply other threads:[~2022-11-29 21:13 UTC|newest]
Thread overview: 28+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-11-29 21:12 allison.henderson [this message]
2022-11-29 21:12 ` [PATCH v6 01/27] xfs: Add new name to attri/d allison.henderson
2022-11-29 21:12 ` [PATCH v6 02/27] xfs: Increase XFS_DEFER_OPS_NR_INODES to 5 allison.henderson
2022-11-29 21:12 ` [PATCH v6 03/27] xfs: Increase XFS_QM_TRANS_MAXDQS " allison.henderson
2022-11-29 21:12 ` [PATCH v6 04/27] xfs: Hold inode locks in xfs_ialloc allison.henderson
2022-11-29 21:12 ` [PATCH v6 05/27] xfs: Hold inode locks in xfs_trans_alloc_dir allison.henderson
2022-11-29 21:12 ` [PATCH v6 06/27] xfs: Hold inode locks in xfs_rename allison.henderson
2022-11-29 21:12 ` [PATCH v6 07/27] xfs: Expose init_xattrs in xfs_create_tmpfile allison.henderson
2022-11-29 21:12 ` [PATCH v6 08/27] xfs: get directory offset when adding directory name allison.henderson
2022-11-29 21:12 ` [PATCH v6 09/27] xfs: get directory offset when removing " allison.henderson
2022-11-29 21:12 ` [PATCH v6 10/27] xfs: get directory offset when replacing a " allison.henderson
2022-11-29 21:12 ` [PATCH v6 11/27] xfs: add parent pointer support to attribute code allison.henderson
2022-11-29 21:12 ` [PATCH v6 12/27] xfs: define parent pointer xattr format allison.henderson
2022-11-29 21:12 ` [PATCH v6 13/27] xfs: Add xfs_verify_pptr allison.henderson
2022-11-29 21:12 ` [PATCH v6 14/27] xfs: extend transaction reservations for parent attributes allison.henderson
2022-11-29 21:12 ` [PATCH v6 15/27] xfs: parent pointer attribute creation allison.henderson
2022-11-29 21:12 ` [PATCH v6 16/27] xfs: add parent attributes to link allison.henderson
2022-11-29 21:12 ` [PATCH v6 17/27] xfs: add parent attributes to symlink allison.henderson
2022-11-29 21:12 ` [PATCH v6 18/27] xfs: remove parent pointers in unlink allison.henderson
2022-11-29 21:12 ` [PATCH v6 19/27] xfs: Indent xfs_rename allison.henderson
2022-11-29 21:12 ` [PATCH v6 20/27] xfs: Add parent pointers to rename allison.henderson
2022-11-29 21:12 ` [PATCH v6 21/27] xfs: Add parent pointers to xfs_cross_rename allison.henderson
2022-11-29 21:12 ` [PATCH v6 22/27] xfs: Add the parent pointer support to the superblock version 5 allison.henderson
2022-11-29 21:12 ` [PATCH v6 23/27] xfs: Add helper function xfs_attr_list_context_init allison.henderson
2022-11-29 21:12 ` [PATCH v6 24/27] xfs: Filter XFS_ATTR_PARENT for getfattr allison.henderson
2022-11-29 21:12 ` [PATCH v6 25/27] xfs: Add parent pointer ioctl allison.henderson
2022-11-29 21:12 ` [PATCH v6 26/27] xfs: fix unit conversion error in xfs_log_calc_max_attrsetm_res allison.henderson
2022-11-29 21:12 ` [PATCH v6 27/27] xfs: drop compatibility minimum log size computations for reflink allison.henderson
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20221129211242.2689855-1-allison.henderson@oracle.com \
--to=allison.henderson@oracle.com \
--cc=linux-xfs@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).