* [PATCH V5 0/2] cleanup and bugfix for xfs tests related to btree format
@ 2022-12-08 7:28 Ziyang Zhang
2022-12-08 7:28 ` [PATCH V5 1/2] common/xfs: Add a helper to export inode core size Ziyang Zhang
2022-12-08 7:28 ` [PATCH V5 2/2] common/populate: Ensure that S_IFDIR.FMT_BTREE is in btree format Ziyang Zhang
0 siblings, 2 replies; 10+ messages in thread
From: Ziyang Zhang @ 2022-12-08 7:28 UTC (permalink / raw)
To: fstests, linux-xfs
Cc: zlang, david, djwong, hsiangkao, allison.henderson, Ziyang Zhang
The first patch add a helper in common/xfs to export the inode core size
which is needed by some xfs test cases.
The second patch ensure that S_IFDIR.FMT_BTREE is in btree format while
populating dir.
V5:
- rename _xfs_inode_core_bytes() to _xfs_get_inode_core_bytes()
- rename _xfs_inode_size() to _xfs_get_inode_size()
- use one pipe in _xfs_get_inode_size()
- use local variables in __populate_xfs_create_btree_dir()
V4:
- let the new helper function accept the "missing" parameter
- make _xfs_inode_core_bytes echo 176 or 96 so tests can work correctly on
both v4 and v5
V3:
- refactor xfs tests cases using inode core size
V2:
- take Darrick's advice to cleanup code
Ziyang Zhang (2):
common/xfs: Add a helper to export inode core size
common/populate: Ensure that S_IFDIR.FMT_BTREE is in btree format
common/populate | 34 +++++++++++++++++++++++++++++++++-
common/xfs | 24 ++++++++++++++++++++++++
tests/xfs/335 | 3 ++-
tests/xfs/336 | 3 ++-
tests/xfs/337 | 3 ++-
tests/xfs/341 | 3 ++-
tests/xfs/342 | 3 ++-
7 files changed, 67 insertions(+), 6 deletions(-)
--
2.18.4
^ permalink raw reply [flat|nested] 10+ messages in thread
* [PATCH V5 1/2] common/xfs: Add a helper to export inode core size
2022-12-08 7:28 [PATCH V5 0/2] cleanup and bugfix for xfs tests related to btree format Ziyang Zhang
@ 2022-12-08 7:28 ` Ziyang Zhang
2022-12-08 7:28 ` [PATCH V5 2/2] common/populate: Ensure that S_IFDIR.FMT_BTREE is in btree format Ziyang Zhang
1 sibling, 0 replies; 10+ messages in thread
From: Ziyang Zhang @ 2022-12-08 7:28 UTC (permalink / raw)
To: fstests, linux-xfs
Cc: zlang, david, djwong, hsiangkao, allison.henderson, Ziyang Zhang
Some xfs test cases need the number of bytes reserved for only the inode
record, excluding the immediate fork areas. Now the value is hard-coded
and it is not a good chioce. Add a helper in common/xfs to export the
inode core size.
Reviewed-by: Allison Henderson <allison.henderson@oracle.com>
Reviewed-by: Darrick J. Wong <djwong@kernel.org>
Signed-off-by: Ziyang Zhang <ZiyangZhang@linux.alibaba.com>
---
common/xfs | 15 +++++++++++++++
tests/xfs/335 | 3 ++-
tests/xfs/336 | 3 ++-
tests/xfs/337 | 3 ++-
tests/xfs/341 | 3 ++-
tests/xfs/342 | 3 ++-
6 files changed, 25 insertions(+), 5 deletions(-)
diff --git a/common/xfs b/common/xfs
index 8ac1964e..674384a9 100644
--- a/common/xfs
+++ b/common/xfs
@@ -1486,3 +1486,18 @@ _require_xfsrestore_xflag()
$XFSRESTORE_PROG -h 2>&1 | grep -q -e '-x' || \
_notrun 'xfsrestore does not support -x flag.'
}
+
+# Number of bytes reserved for only the inode record, excluding the
+# immediate fork areas.
+_xfs_get_inode_core_bytes()
+{
+ local dir="$1"
+
+ if _xfs_has_feature "$dir" crc; then
+ # v5 filesystems
+ echo 176
+ else
+ # v4 filesystems
+ echo 96
+ fi
+}
diff --git a/tests/xfs/335 b/tests/xfs/335
index ccc508e7..3f5223ee 100755
--- a/tests/xfs/335
+++ b/tests/xfs/335
@@ -31,7 +31,8 @@ blksz="$(_get_block_size $SCRATCH_MNT)"
echo "Create a three-level rtrmapbt"
# inode core size is at least 176 bytes; btree header is 56 bytes;
# rtrmap record is 32 bytes; and rtrmap key/pointer are 56 bytes.
-i_ptrs=$(( (isize - 176) / 56 ))
+i_core_size="$(_xfs_get_inode_core_bytes $SCRATCH_MNT)"
+i_ptrs=$(( (isize - i_core_size) / 56 ))
bt_ptrs=$(( (blksz - 56) / 56 ))
bt_recs=$(( (blksz - 56) / 32 ))
diff --git a/tests/xfs/336 b/tests/xfs/336
index b1de8e5f..a686fab4 100755
--- a/tests/xfs/336
+++ b/tests/xfs/336
@@ -42,7 +42,8 @@ rm -rf $metadump_file
echo "Create a three-level rtrmapbt"
# inode core size is at least 176 bytes; btree header is 56 bytes;
# rtrmap record is 32 bytes; and rtrmap key/pointer are 56 bytes.
-i_ptrs=$(( (isize - 176) / 56 ))
+i_core_size="$(_xfs_get_inode_core_bytes $SCRATCH_MNT)"
+i_ptrs=$(( (isize - i_core_size) / 56 ))
bt_ptrs=$(( (blksz - 56) / 56 ))
bt_recs=$(( (blksz - 56) / 32 ))
diff --git a/tests/xfs/337 b/tests/xfs/337
index a2515e36..3bdef4e3 100755
--- a/tests/xfs/337
+++ b/tests/xfs/337
@@ -33,7 +33,8 @@ blksz="$(_get_block_size $SCRATCH_MNT)"
# inode core size is at least 176 bytes; btree header is 56 bytes;
# rtrmap record is 32 bytes; and rtrmap key/pointer are 56 bytes.
-i_ptrs=$(( (isize - 176) / 56 ))
+i_core_size="$(_xfs_get_inode_core_bytes $SCRATCH_MNT)"
+i_ptrs=$(( (isize - i_core_size) / 56 ))
bt_ptrs=$(( (blksz - 56) / 56 ))
bt_recs=$(( (blksz - 56) / 32 ))
diff --git a/tests/xfs/341 b/tests/xfs/341
index f026aa37..72f75318 100755
--- a/tests/xfs/341
+++ b/tests/xfs/341
@@ -33,7 +33,8 @@ rtextsz_blks=$((rtextsz / blksz))
# inode core size is at least 176 bytes; btree header is 56 bytes;
# rtrmap record is 32 bytes; and rtrmap key/pointer are 56 bytes.
-i_ptrs=$(( (isize - 176) / 56 ))
+i_core_size="$(_xfs_get_inode_core_bytes $SCRATCH_MNT)"
+i_ptrs=$(( (isize - i_core_size) / 56 ))
bt_recs=$(( (blksz - 56) / 32 ))
blocks=$((i_ptrs * bt_recs + 1))
diff --git a/tests/xfs/342 b/tests/xfs/342
index 1ae414eb..0b3b136c 100755
--- a/tests/xfs/342
+++ b/tests/xfs/342
@@ -30,7 +30,8 @@ blksz="$(_get_block_size $SCRATCH_MNT)"
# inode core size is at least 176 bytes; btree header is 56 bytes;
# rtrmap record is 32 bytes; and rtrmap key/pointer are 56 bytes.
-i_ptrs=$(( (isize - 176) / 56 ))
+i_core_size="$(_xfs_get_inode_core_bytes $SCRATCH_MNT)"
+i_ptrs=$(( (isize - i_core_size) / 56 ))
bt_recs=$(( (blksz - 56) / 32 ))
blocks=$((i_ptrs * bt_recs + 1))
--
2.18.4
^ permalink raw reply related [flat|nested] 10+ messages in thread
* [PATCH V5 2/2] common/populate: Ensure that S_IFDIR.FMT_BTREE is in btree format
2022-12-08 7:28 [PATCH V5 0/2] cleanup and bugfix for xfs tests related to btree format Ziyang Zhang
2022-12-08 7:28 ` [PATCH V5 1/2] common/xfs: Add a helper to export inode core size Ziyang Zhang
@ 2022-12-08 7:28 ` Ziyang Zhang
2022-12-09 16:37 ` Darrick J. Wong
1 sibling, 1 reply; 10+ messages in thread
From: Ziyang Zhang @ 2022-12-08 7:28 UTC (permalink / raw)
To: fstests, linux-xfs
Cc: zlang, david, djwong, hsiangkao, allison.henderson, Ziyang Zhang
Sometimes "$((128 * dblksz / 40))" dirents cannot make sure that
S_IFDIR.FMT_BTREE could become btree format for its DATA fork.
Actually we just observed it can fail after apply our inode
extent-to-btree workaround. The root cause is that the kernel may be
too good at allocating consecutive blocks so that the data fork is
still in extents format.
Therefore instead of using a fixed number, let's make sure the number
of extents is large enough than (inode size - inode core size) /
sizeof(xfs_bmbt_rec_t).
Reviewed-by: Zorro Lang <zlang@redhat.com>
Reviewed-by: Allison Henderson <allison.henderson@oracle.com>
Suggested-by: "Darrick J. Wong" <djwong@kernel.org>
Signed-off-by: Gao Xiang <hsiangkao@linux.alibaba.com>
Signed-off-by: Ziyang Zhang <ZiyangZhang@linux.alibaba.com>
---
common/populate | 34 +++++++++++++++++++++++++++++++++-
common/xfs | 9 +++++++++
2 files changed, 42 insertions(+), 1 deletion(-)
diff --git a/common/populate b/common/populate
index 6e004997..0d334a13 100644
--- a/common/populate
+++ b/common/populate
@@ -71,6 +71,37 @@ __populate_create_dir() {
done
}
+# Create a large directory and ensure that it's a btree format
+__populate_xfs_create_btree_dir() {
+ local name="$1"
+ local isize="$2"
+ local missing="$3"
+ local icore_size="$(_xfs_inode_core_bytes)"
+ # We need enough extents to guarantee that the data fork is in
+ # btree format. Cycling the mount to use xfs_db is too slow, so
+ # watch for when the extent count exceeds the space after the
+ # inode core.
+ local max_nextents="$(((isize - icore_size) / 16))"
+ local nr=0
+
+ mkdir -p "${name}"
+ while true; do
+ local creat=mkdir
+ test "$((nr % 20))" -eq 0 && creat=touch
+ $creat "${name}/$(printf "%.08d" "$nr")"
+ if [ "$((nr % 40))" -eq 0 ]; then
+ local nextents="$(_xfs_get_fsxattr nextents $name)"
+ [ $nextents -gt $max_nextents ] && break
+ fi
+ nr=$((nr+1))
+ done
+
+ test -z "${missing}" && return
+ seq 1 2 "${nr}" | while read d; do
+ rm -rf "${name}/$(printf "%.08d" "$d")"
+ done
+}
+
# Add a bunch of attrs to a file
__populate_create_attr() {
name="$1"
@@ -176,6 +207,7 @@ _scratch_xfs_populate() {
blksz="$(stat -f -c '%s' "${SCRATCH_MNT}")"
dblksz="$(_xfs_get_dir_blocksize "$SCRATCH_MNT")"
+ isize="$(_xfs_get_inode_size "$SCRATCH_MNT")"
crc="$(_xfs_has_feature "$SCRATCH_MNT" crc -v)"
if [ $crc -eq 1 ]; then
leaf_hdr_size=64
@@ -226,7 +258,7 @@ _scratch_xfs_populate() {
# - BTREE
echo "+ btree dir"
- __populate_create_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$((128 * dblksz / 40))" true
+ __populate_xfs_create_btree_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$isize" true
# Symlinks
# - FMT_LOCAL
diff --git a/common/xfs b/common/xfs
index 674384a9..7aaa63c7 100644
--- a/common/xfs
+++ b/common/xfs
@@ -1487,6 +1487,15 @@ _require_xfsrestore_xflag()
_notrun 'xfsrestore does not support -x flag.'
}
+# Number of bytes reserved for a full inode record, which includes the
+# immediate fork areas.
+_xfs_get_inode_size()
+{
+ local mntpoint="$1"
+
+ $XFS_INFO_PROG "$mntpoint" | sed -n '/meta-data=.*isize/s/^.*isize=\([0-9]*\).*$/\1/p'
+}
+
# Number of bytes reserved for only the inode record, excluding the
# immediate fork areas.
_xfs_get_inode_core_bytes()
--
2.18.4
^ permalink raw reply related [flat|nested] 10+ messages in thread
* Re: [PATCH V5 2/2] common/populate: Ensure that S_IFDIR.FMT_BTREE is in btree format
2022-12-08 7:28 ` [PATCH V5 2/2] common/populate: Ensure that S_IFDIR.FMT_BTREE is in btree format Ziyang Zhang
@ 2022-12-09 16:37 ` Darrick J. Wong
2022-12-10 13:57 ` Zorro Lang
0 siblings, 1 reply; 10+ messages in thread
From: Darrick J. Wong @ 2022-12-09 16:37 UTC (permalink / raw)
To: Ziyang Zhang
Cc: fstests, linux-xfs, zlang, david, hsiangkao, allison.henderson
On Thu, Dec 08, 2022 at 03:28:43PM +0800, Ziyang Zhang wrote:
> Sometimes "$((128 * dblksz / 40))" dirents cannot make sure that
> S_IFDIR.FMT_BTREE could become btree format for its DATA fork.
>
> Actually we just observed it can fail after apply our inode
> extent-to-btree workaround. The root cause is that the kernel may be
> too good at allocating consecutive blocks so that the data fork is
> still in extents format.
>
> Therefore instead of using a fixed number, let's make sure the number
> of extents is large enough than (inode size - inode core size) /
> sizeof(xfs_bmbt_rec_t).
>
> Reviewed-by: Zorro Lang <zlang@redhat.com>
> Reviewed-by: Allison Henderson <allison.henderson@oracle.com>
> Suggested-by: "Darrick J. Wong" <djwong@kernel.org>
> Signed-off-by: Gao Xiang <hsiangkao@linux.alibaba.com>
> Signed-off-by: Ziyang Zhang <ZiyangZhang@linux.alibaba.com>
> ---
> common/populate | 34 +++++++++++++++++++++++++++++++++-
> common/xfs | 9 +++++++++
> 2 files changed, 42 insertions(+), 1 deletion(-)
>
> diff --git a/common/populate b/common/populate
> index 6e004997..0d334a13 100644
> --- a/common/populate
> +++ b/common/populate
> @@ -71,6 +71,37 @@ __populate_create_dir() {
> done
> }
>
> +# Create a large directory and ensure that it's a btree format
> +__populate_xfs_create_btree_dir() {
> + local name="$1"
> + local isize="$2"
> + local missing="$3"
> + local icore_size="$(_xfs_inode_core_bytes)"
Doesn't this helper require a path argument now?
--D
> + # We need enough extents to guarantee that the data fork is in
> + # btree format. Cycling the mount to use xfs_db is too slow, so
> + # watch for when the extent count exceeds the space after the
> + # inode core.
> + local max_nextents="$(((isize - icore_size) / 16))"
> + local nr=0
> +
> + mkdir -p "${name}"
> + while true; do
> + local creat=mkdir
> + test "$((nr % 20))" -eq 0 && creat=touch
> + $creat "${name}/$(printf "%.08d" "$nr")"
> + if [ "$((nr % 40))" -eq 0 ]; then
> + local nextents="$(_xfs_get_fsxattr nextents $name)"
> + [ $nextents -gt $max_nextents ] && break
> + fi
> + nr=$((nr+1))
> + done
> +
> + test -z "${missing}" && return
> + seq 1 2 "${nr}" | while read d; do
> + rm -rf "${name}/$(printf "%.08d" "$d")"
> + done
> +}
> +
> # Add a bunch of attrs to a file
> __populate_create_attr() {
> name="$1"
> @@ -176,6 +207,7 @@ _scratch_xfs_populate() {
>
> blksz="$(stat -f -c '%s' "${SCRATCH_MNT}")"
> dblksz="$(_xfs_get_dir_blocksize "$SCRATCH_MNT")"
> + isize="$(_xfs_get_inode_size "$SCRATCH_MNT")"
> crc="$(_xfs_has_feature "$SCRATCH_MNT" crc -v)"
> if [ $crc -eq 1 ]; then
> leaf_hdr_size=64
> @@ -226,7 +258,7 @@ _scratch_xfs_populate() {
>
> # - BTREE
> echo "+ btree dir"
> - __populate_create_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$((128 * dblksz / 40))" true
> + __populate_xfs_create_btree_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$isize" true
>
> # Symlinks
> # - FMT_LOCAL
> diff --git a/common/xfs b/common/xfs
> index 674384a9..7aaa63c7 100644
> --- a/common/xfs
> +++ b/common/xfs
> @@ -1487,6 +1487,15 @@ _require_xfsrestore_xflag()
> _notrun 'xfsrestore does not support -x flag.'
> }
>
> +# Number of bytes reserved for a full inode record, which includes the
> +# immediate fork areas.
> +_xfs_get_inode_size()
> +{
> + local mntpoint="$1"
> +
> + $XFS_INFO_PROG "$mntpoint" | sed -n '/meta-data=.*isize/s/^.*isize=\([0-9]*\).*$/\1/p'
> +}
> +
> # Number of bytes reserved for only the inode record, excluding the
> # immediate fork areas.
> _xfs_get_inode_core_bytes()
> --
> 2.18.4
>
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH V5 2/2] common/populate: Ensure that S_IFDIR.FMT_BTREE is in btree format
2022-12-09 16:37 ` Darrick J. Wong
@ 2022-12-10 13:57 ` Zorro Lang
2022-12-11 2:30 ` Darrick J. Wong
0 siblings, 1 reply; 10+ messages in thread
From: Zorro Lang @ 2022-12-10 13:57 UTC (permalink / raw)
To: Darrick J. Wong; +Cc: Ziyang Zhang, fstests, linux-xfs, hsiangkao
On Fri, Dec 09, 2022 at 08:37:41AM -0800, Darrick J. Wong wrote:
> On Thu, Dec 08, 2022 at 03:28:43PM +0800, Ziyang Zhang wrote:
> > Sometimes "$((128 * dblksz / 40))" dirents cannot make sure that
> > S_IFDIR.FMT_BTREE could become btree format for its DATA fork.
> >
> > Actually we just observed it can fail after apply our inode
> > extent-to-btree workaround. The root cause is that the kernel may be
> > too good at allocating consecutive blocks so that the data fork is
> > still in extents format.
> >
> > Therefore instead of using a fixed number, let's make sure the number
> > of extents is large enough than (inode size - inode core size) /
> > sizeof(xfs_bmbt_rec_t).
> >
> > Reviewed-by: Zorro Lang <zlang@redhat.com>
> > Reviewed-by: Allison Henderson <allison.henderson@oracle.com>
> > Suggested-by: "Darrick J. Wong" <djwong@kernel.org>
> > Signed-off-by: Gao Xiang <hsiangkao@linux.alibaba.com>
> > Signed-off-by: Ziyang Zhang <ZiyangZhang@linux.alibaba.com>
> > ---
> > common/populate | 34 +++++++++++++++++++++++++++++++++-
> > common/xfs | 9 +++++++++
> > 2 files changed, 42 insertions(+), 1 deletion(-)
> >
> > diff --git a/common/populate b/common/populate
> > index 6e004997..0d334a13 100644
> > --- a/common/populate
> > +++ b/common/populate
> > @@ -71,6 +71,37 @@ __populate_create_dir() {
> > done
> > }
> >
> > +# Create a large directory and ensure that it's a btree format
> > +__populate_xfs_create_btree_dir() {
> > + local name="$1"
> > + local isize="$2"
> > + local missing="$3"
> > + local icore_size="$(_xfs_inode_core_bytes)"
>
> Doesn't this helper require a path argument now?
What kind of "path" argument? I think he copy it from __populate_create_dir(),
and keep using the "name" as the root path to create files/dir.
>
> --D
>
> > + # We need enough extents to guarantee that the data fork is in
> > + # btree format. Cycling the mount to use xfs_db is too slow, so
> > + # watch for when the extent count exceeds the space after the
> > + # inode core.
> > + local max_nextents="$(((isize - icore_size) / 16))"
> > + local nr=0
> > +
> > + mkdir -p "${name}"
> > + while true; do
> > + local creat=mkdir
> > + test "$((nr % 20))" -eq 0 && creat=touch
> > + $creat "${name}/$(printf "%.08d" "$nr")"
> > + if [ "$((nr % 40))" -eq 0 ]; then
> > + local nextents="$(_xfs_get_fsxattr nextents $name)"
> > + [ $nextents -gt $max_nextents ] && break
> > + fi
> > + nr=$((nr+1))
> > + done
> > +
> > + test -z "${missing}" && return
> > + seq 1 2 "${nr}" | while read d; do
> > + rm -rf "${name}/$(printf "%.08d" "$d")"
> > + done
> > +}
> > +
> > # Add a bunch of attrs to a file
> > __populate_create_attr() {
> > name="$1"
> > @@ -176,6 +207,7 @@ _scratch_xfs_populate() {
> >
> > blksz="$(stat -f -c '%s' "${SCRATCH_MNT}")"
> > dblksz="$(_xfs_get_dir_blocksize "$SCRATCH_MNT")"
> > + isize="$(_xfs_get_inode_size "$SCRATCH_MNT")"
> > crc="$(_xfs_has_feature "$SCRATCH_MNT" crc -v)"
> > if [ $crc -eq 1 ]; then
> > leaf_hdr_size=64
> > @@ -226,7 +258,7 @@ _scratch_xfs_populate() {
> >
> > # - BTREE
> > echo "+ btree dir"
> > - __populate_create_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$((128 * dblksz / 40))" true
> > + __populate_xfs_create_btree_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$isize" true
> >
> > # Symlinks
> > # - FMT_LOCAL
> > diff --git a/common/xfs b/common/xfs
> > index 674384a9..7aaa63c7 100644
> > --- a/common/xfs
> > +++ b/common/xfs
> > @@ -1487,6 +1487,15 @@ _require_xfsrestore_xflag()
> > _notrun 'xfsrestore does not support -x flag.'
> > }
> >
> > +# Number of bytes reserved for a full inode record, which includes the
> > +# immediate fork areas.
> > +_xfs_get_inode_size()
> > +{
> > + local mntpoint="$1"
> > +
> > + $XFS_INFO_PROG "$mntpoint" | sed -n '/meta-data=.*isize/s/^.*isize=\([0-9]*\).*$/\1/p'
> > +}
> > +
> > # Number of bytes reserved for only the inode record, excluding the
> > # immediate fork areas.
> > _xfs_get_inode_core_bytes()
> > --
> > 2.18.4
> >
>
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH V5 2/2] common/populate: Ensure that S_IFDIR.FMT_BTREE is in btree format
2022-12-10 13:57 ` Zorro Lang
@ 2022-12-11 2:30 ` Darrick J. Wong
2022-12-11 11:01 ` Zorro Lang
0 siblings, 1 reply; 10+ messages in thread
From: Darrick J. Wong @ 2022-12-11 2:30 UTC (permalink / raw)
To: Zorro Lang; +Cc: Ziyang Zhang, fstests, linux-xfs, hsiangkao
On Sat, Dec 10, 2022 at 09:57:24PM +0800, Zorro Lang wrote:
> On Fri, Dec 09, 2022 at 08:37:41AM -0800, Darrick J. Wong wrote:
> > On Thu, Dec 08, 2022 at 03:28:43PM +0800, Ziyang Zhang wrote:
> > > Sometimes "$((128 * dblksz / 40))" dirents cannot make sure that
> > > S_IFDIR.FMT_BTREE could become btree format for its DATA fork.
> > >
> > > Actually we just observed it can fail after apply our inode
> > > extent-to-btree workaround. The root cause is that the kernel may be
> > > too good at allocating consecutive blocks so that the data fork is
> > > still in extents format.
> > >
> > > Therefore instead of using a fixed number, let's make sure the number
> > > of extents is large enough than (inode size - inode core size) /
> > > sizeof(xfs_bmbt_rec_t).
> > >
> > > Reviewed-by: Zorro Lang <zlang@redhat.com>
> > > Reviewed-by: Allison Henderson <allison.henderson@oracle.com>
> > > Suggested-by: "Darrick J. Wong" <djwong@kernel.org>
> > > Signed-off-by: Gao Xiang <hsiangkao@linux.alibaba.com>
> > > Signed-off-by: Ziyang Zhang <ZiyangZhang@linux.alibaba.com>
> > > ---
> > > common/populate | 34 +++++++++++++++++++++++++++++++++-
> > > common/xfs | 9 +++++++++
> > > 2 files changed, 42 insertions(+), 1 deletion(-)
> > >
> > > diff --git a/common/populate b/common/populate
> > > index 6e004997..0d334a13 100644
> > > --- a/common/populate
> > > +++ b/common/populate
> > > @@ -71,6 +71,37 @@ __populate_create_dir() {
> > > done
> > > }
> > >
> > > +# Create a large directory and ensure that it's a btree format
> > > +__populate_xfs_create_btree_dir() {
> > > + local name="$1"
> > > + local isize="$2"
> > > + local missing="$3"
> > > + local icore_size="$(_xfs_inode_core_bytes)"
> >
> > Doesn't this helper require a path argument now?
>
> What kind of "path" argument? I think he copy it from __populate_create_dir(),
> and keep using the "name" as the root path to create files/dir.
This path argument, from
https://lore.kernel.org/fstests/20221208072843.1866615-2-ZiyangZhang@linux.alibaba.com/T/#u
+# Number of bytes reserved for only the inode record, excluding the
+# immediate fork areas.
+_xfs_get_inode_core_bytes()
+{
+ local dir="$1"
+
+ if _xfs_has_feature "$dir" crc; then
--D
> >
> > --D
> >
> > > + # We need enough extents to guarantee that the data fork is in
> > > + # btree format. Cycling the mount to use xfs_db is too slow, so
> > > + # watch for when the extent count exceeds the space after the
> > > + # inode core.
> > > + local max_nextents="$(((isize - icore_size) / 16))"
> > > + local nr=0
> > > +
> > > + mkdir -p "${name}"
> > > + while true; do
> > > + local creat=mkdir
> > > + test "$((nr % 20))" -eq 0 && creat=touch
> > > + $creat "${name}/$(printf "%.08d" "$nr")"
> > > + if [ "$((nr % 40))" -eq 0 ]; then
> > > + local nextents="$(_xfs_get_fsxattr nextents $name)"
> > > + [ $nextents -gt $max_nextents ] && break
> > > + fi
> > > + nr=$((nr+1))
> > > + done
> > > +
> > > + test -z "${missing}" && return
> > > + seq 1 2 "${nr}" | while read d; do
> > > + rm -rf "${name}/$(printf "%.08d" "$d")"
> > > + done
> > > +}
> > > +
> > > # Add a bunch of attrs to a file
> > > __populate_create_attr() {
> > > name="$1"
> > > @@ -176,6 +207,7 @@ _scratch_xfs_populate() {
> > >
> > > blksz="$(stat -f -c '%s' "${SCRATCH_MNT}")"
> > > dblksz="$(_xfs_get_dir_blocksize "$SCRATCH_MNT")"
> > > + isize="$(_xfs_get_inode_size "$SCRATCH_MNT")"
> > > crc="$(_xfs_has_feature "$SCRATCH_MNT" crc -v)"
> > > if [ $crc -eq 1 ]; then
> > > leaf_hdr_size=64
> > > @@ -226,7 +258,7 @@ _scratch_xfs_populate() {
> > >
> > > # - BTREE
> > > echo "+ btree dir"
> > > - __populate_create_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$((128 * dblksz / 40))" true
> > > + __populate_xfs_create_btree_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$isize" true
> > >
> > > # Symlinks
> > > # - FMT_LOCAL
> > > diff --git a/common/xfs b/common/xfs
> > > index 674384a9..7aaa63c7 100644
> > > --- a/common/xfs
> > > +++ b/common/xfs
> > > @@ -1487,6 +1487,15 @@ _require_xfsrestore_xflag()
> > > _notrun 'xfsrestore does not support -x flag.'
> > > }
> > >
> > > +# Number of bytes reserved for a full inode record, which includes the
> > > +# immediate fork areas.
> > > +_xfs_get_inode_size()
> > > +{
> > > + local mntpoint="$1"
> > > +
> > > + $XFS_INFO_PROG "$mntpoint" | sed -n '/meta-data=.*isize/s/^.*isize=\([0-9]*\).*$/\1/p'
> > > +}
> > > +
> > > # Number of bytes reserved for only the inode record, excluding the
> > > # immediate fork areas.
> > > _xfs_get_inode_core_bytes()
> > > --
> > > 2.18.4
> > >
> >
>
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH V5 2/2] common/populate: Ensure that S_IFDIR.FMT_BTREE is in btree format
2022-12-11 2:30 ` Darrick J. Wong
@ 2022-12-11 11:01 ` Zorro Lang
2022-12-11 11:23 ` Zorro Lang
2022-12-12 3:43 ` Ziyang Zhang
0 siblings, 2 replies; 10+ messages in thread
From: Zorro Lang @ 2022-12-11 11:01 UTC (permalink / raw)
To: Darrick J. Wong; +Cc: Ziyang Zhang, fstests, linux-xfs, hsiangkao
On Sat, Dec 10, 2022 at 06:30:10PM -0800, Darrick J. Wong wrote:
> On Sat, Dec 10, 2022 at 09:57:24PM +0800, Zorro Lang wrote:
> > On Fri, Dec 09, 2022 at 08:37:41AM -0800, Darrick J. Wong wrote:
> > > On Thu, Dec 08, 2022 at 03:28:43PM +0800, Ziyang Zhang wrote:
> > > > Sometimes "$((128 * dblksz / 40))" dirents cannot make sure that
> > > > S_IFDIR.FMT_BTREE could become btree format for its DATA fork.
> > > >
> > > > Actually we just observed it can fail after apply our inode
> > > > extent-to-btree workaround. The root cause is that the kernel may be
> > > > too good at allocating consecutive blocks so that the data fork is
> > > > still in extents format.
> > > >
> > > > Therefore instead of using a fixed number, let's make sure the number
> > > > of extents is large enough than (inode size - inode core size) /
> > > > sizeof(xfs_bmbt_rec_t).
> > > >
> > > > Reviewed-by: Zorro Lang <zlang@redhat.com>
> > > > Reviewed-by: Allison Henderson <allison.henderson@oracle.com>
> > > > Suggested-by: "Darrick J. Wong" <djwong@kernel.org>
> > > > Signed-off-by: Gao Xiang <hsiangkao@linux.alibaba.com>
> > > > Signed-off-by: Ziyang Zhang <ZiyangZhang@linux.alibaba.com>
> > > > ---
> > > > common/populate | 34 +++++++++++++++++++++++++++++++++-
> > > > common/xfs | 9 +++++++++
> > > > 2 files changed, 42 insertions(+), 1 deletion(-)
> > > >
> > > > diff --git a/common/populate b/common/populate
> > > > index 6e004997..0d334a13 100644
> > > > --- a/common/populate
> > > > +++ b/common/populate
> > > > @@ -71,6 +71,37 @@ __populate_create_dir() {
> > > > done
> > > > }
> > > >
> > > > +# Create a large directory and ensure that it's a btree format
> > > > +__populate_xfs_create_btree_dir() {
> > > > + local name="$1"
> > > > + local isize="$2"
> > > > + local missing="$3"
> > > > + local icore_size="$(_xfs_inode_core_bytes)"
> > >
> > > Doesn't this helper require a path argument now?
> >
> > What kind of "path" argument? I think he copy it from __populate_create_dir(),
> > and keep using the "name" as the root path to create files/dir.
>
> This path argument, from
> https://lore.kernel.org/fstests/20221208072843.1866615-2-ZiyangZhang@linux.alibaba.com/T/#u
>
> +# Number of bytes reserved for only the inode record, excluding the
> +# immediate fork areas.
> +_xfs_get_inode_core_bytes()
> +{
> + local dir="$1"
> +
> + if _xfs_has_feature "$dir" crc; then
Oh, sorry I thought you mean __populate_xfs_create_btree_dir() require a path
argument...
Yes, and this helper's name should be _xfs_get_inode_core_bytes(), not
_xfs_inode_core_bytes(). I didn't find _xfs_inode_core_bytes from current
fstests. So it should be:
local icore_size="$(_xfs_get_inode_core_bytes $SCRATCH_MNT)"
Hi Ziyang,
Please modify this place, and check all other places which call
_xfs_get_inode_core_bytes and _xfs_get_inode_size, to make sure
they're all changed correctly.
Thanks,
Zorro
>
> --D
>
> > >
> > > --D
> > >
> > > > + # We need enough extents to guarantee that the data fork is in
> > > > + # btree format. Cycling the mount to use xfs_db is too slow, so
> > > > + # watch for when the extent count exceeds the space after the
> > > > + # inode core.
> > > > + local max_nextents="$(((isize - icore_size) / 16))"
> > > > + local nr=0
> > > > +
> > > > + mkdir -p "${name}"
> > > > + while true; do
> > > > + local creat=mkdir
> > > > + test "$((nr % 20))" -eq 0 && creat=touch
> > > > + $creat "${name}/$(printf "%.08d" "$nr")"
> > > > + if [ "$((nr % 40))" -eq 0 ]; then
> > > > + local nextents="$(_xfs_get_fsxattr nextents $name)"
> > > > + [ $nextents -gt $max_nextents ] && break
> > > > + fi
> > > > + nr=$((nr+1))
> > > > + done
> > > > +
> > > > + test -z "${missing}" && return
> > > > + seq 1 2 "${nr}" | while read d; do
> > > > + rm -rf "${name}/$(printf "%.08d" "$d")"
> > > > + done
> > > > +}
> > > > +
> > > > # Add a bunch of attrs to a file
> > > > __populate_create_attr() {
> > > > name="$1"
> > > > @@ -176,6 +207,7 @@ _scratch_xfs_populate() {
> > > >
> > > > blksz="$(stat -f -c '%s' "${SCRATCH_MNT}")"
> > > > dblksz="$(_xfs_get_dir_blocksize "$SCRATCH_MNT")"
> > > > + isize="$(_xfs_get_inode_size "$SCRATCH_MNT")"
> > > > crc="$(_xfs_has_feature "$SCRATCH_MNT" crc -v)"
> > > > if [ $crc -eq 1 ]; then
> > > > leaf_hdr_size=64
> > > > @@ -226,7 +258,7 @@ _scratch_xfs_populate() {
> > > >
> > > > # - BTREE
> > > > echo "+ btree dir"
> > > > - __populate_create_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$((128 * dblksz / 40))" true
> > > > + __populate_xfs_create_btree_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$isize" true
> > > >
> > > > # Symlinks
> > > > # - FMT_LOCAL
> > > > diff --git a/common/xfs b/common/xfs
> > > > index 674384a9..7aaa63c7 100644
> > > > --- a/common/xfs
> > > > +++ b/common/xfs
> > > > @@ -1487,6 +1487,15 @@ _require_xfsrestore_xflag()
> > > > _notrun 'xfsrestore does not support -x flag.'
> > > > }
> > > >
> > > > +# Number of bytes reserved for a full inode record, which includes the
> > > > +# immediate fork areas.
> > > > +_xfs_get_inode_size()
> > > > +{
> > > > + local mntpoint="$1"
> > > > +
> > > > + $XFS_INFO_PROG "$mntpoint" | sed -n '/meta-data=.*isize/s/^.*isize=\([0-9]*\).*$/\1/p'
> > > > +}
> > > > +
> > > > # Number of bytes reserved for only the inode record, excluding the
> > > > # immediate fork areas.
> > > > _xfs_get_inode_core_bytes()
> > > > --
> > > > 2.18.4
> > > >
> > >
> >
>
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH V5 2/2] common/populate: Ensure that S_IFDIR.FMT_BTREE is in btree format
2022-12-11 11:01 ` Zorro Lang
@ 2022-12-11 11:23 ` Zorro Lang
2022-12-11 19:19 ` Darrick J. Wong
2022-12-12 3:43 ` Ziyang Zhang
1 sibling, 1 reply; 10+ messages in thread
From: Zorro Lang @ 2022-12-11 11:23 UTC (permalink / raw)
To: Darrick J. Wong; +Cc: Ziyang Zhang, fstests, linux-xfs, hsiangkao
On Sun, Dec 11, 2022 at 07:01:25PM +0800, Zorro Lang wrote:
> On Sat, Dec 10, 2022 at 06:30:10PM -0800, Darrick J. Wong wrote:
> > On Sat, Dec 10, 2022 at 09:57:24PM +0800, Zorro Lang wrote:
> > > On Fri, Dec 09, 2022 at 08:37:41AM -0800, Darrick J. Wong wrote:
> > > > On Thu, Dec 08, 2022 at 03:28:43PM +0800, Ziyang Zhang wrote:
> > > > > Sometimes "$((128 * dblksz / 40))" dirents cannot make sure that
> > > > > S_IFDIR.FMT_BTREE could become btree format for its DATA fork.
> > > > >
> > > > > Actually we just observed it can fail after apply our inode
> > > > > extent-to-btree workaround. The root cause is that the kernel may be
> > > > > too good at allocating consecutive blocks so that the data fork is
> > > > > still in extents format.
> > > > >
> > > > > Therefore instead of using a fixed number, let's make sure the number
> > > > > of extents is large enough than (inode size - inode core size) /
> > > > > sizeof(xfs_bmbt_rec_t).
> > > > >
> > > > > Reviewed-by: Zorro Lang <zlang@redhat.com>
> > > > > Reviewed-by: Allison Henderson <allison.henderson@oracle.com>
> > > > > Suggested-by: "Darrick J. Wong" <djwong@kernel.org>
> > > > > Signed-off-by: Gao Xiang <hsiangkao@linux.alibaba.com>
> > > > > Signed-off-by: Ziyang Zhang <ZiyangZhang@linux.alibaba.com>
> > > > > ---
> > > > > common/populate | 34 +++++++++++++++++++++++++++++++++-
> > > > > common/xfs | 9 +++++++++
> > > > > 2 files changed, 42 insertions(+), 1 deletion(-)
> > > > >
> > > > > diff --git a/common/populate b/common/populate
> > > > > index 6e004997..0d334a13 100644
> > > > > --- a/common/populate
> > > > > +++ b/common/populate
> > > > > @@ -71,6 +71,37 @@ __populate_create_dir() {
> > > > > done
> > > > > }
> > > > >
> > > > > +# Create a large directory and ensure that it's a btree format
> > > > > +__populate_xfs_create_btree_dir() {
> > > > > + local name="$1"
> > > > > + local isize="$2"
> > > > > + local missing="$3"
> > > > > + local icore_size="$(_xfs_inode_core_bytes)"
> > > >
> > > > Doesn't this helper require a path argument now?
> > >
> > > What kind of "path" argument? I think he copy it from __populate_create_dir(),
> > > and keep using the "name" as the root path to create files/dir.
> >
> > This path argument, from
> > https://lore.kernel.org/fstests/20221208072843.1866615-2-ZiyangZhang@linux.alibaba.com/T/#u
> >
> > +# Number of bytes reserved for only the inode record, excluding the
> > +# immediate fork areas.
> > +_xfs_get_inode_core_bytes()
> > +{
> > + local dir="$1"
> > +
> > + if _xfs_has_feature "$dir" crc; then
>
> Oh, sorry I thought you mean __populate_xfs_create_btree_dir() require a path
> argument...
>
> Yes, and this helper's name should be _xfs_get_inode_core_bytes(), not
> _xfs_inode_core_bytes(). I didn't find _xfs_inode_core_bytes from current
> fstests. So it should be:
>
> local icore_size="$(_xfs_get_inode_core_bytes $SCRATCH_MNT)"
Hmm... wait a moment. The work directory of __populate_xfs_create_btree_dir() is
"local name=$1", but the "$name" maybe not a mountpoint.
So we need to get the fs dev/mnt before calling _xfs_get_inode_core_bytes:
local icore_size="$(_xfs_get_inode_core_bytes `_df_dir $name | awk '{print $1}'`)"
Or use $TEST_MNT directly?
Thanks,
Zorro
>
> Hi Ziyang,
>
> Please modify this place, and check all other places which call
> _xfs_get_inode_core_bytes and _xfs_get_inode_size, to make sure
> they're all changed correctly.
>
> Thanks,
> Zorro
>
>
> >
> > --D
> >
> > > >
> > > > --D
> > > >
> > > > > + # We need enough extents to guarantee that the data fork is in
> > > > > + # btree format. Cycling the mount to use xfs_db is too slow, so
> > > > > + # watch for when the extent count exceeds the space after the
> > > > > + # inode core.
> > > > > + local max_nextents="$(((isize - icore_size) / 16))"
> > > > > + local nr=0
> > > > > +
> > > > > + mkdir -p "${name}"
> > > > > + while true; do
> > > > > + local creat=mkdir
> > > > > + test "$((nr % 20))" -eq 0 && creat=touch
> > > > > + $creat "${name}/$(printf "%.08d" "$nr")"
> > > > > + if [ "$((nr % 40))" -eq 0 ]; then
> > > > > + local nextents="$(_xfs_get_fsxattr nextents $name)"
> > > > > + [ $nextents -gt $max_nextents ] && break
> > > > > + fi
> > > > > + nr=$((nr+1))
> > > > > + done
> > > > > +
> > > > > + test -z "${missing}" && return
> > > > > + seq 1 2 "${nr}" | while read d; do
> > > > > + rm -rf "${name}/$(printf "%.08d" "$d")"
> > > > > + done
> > > > > +}
> > > > > +
> > > > > # Add a bunch of attrs to a file
> > > > > __populate_create_attr() {
> > > > > name="$1"
> > > > > @@ -176,6 +207,7 @@ _scratch_xfs_populate() {
> > > > >
> > > > > blksz="$(stat -f -c '%s' "${SCRATCH_MNT}")"
> > > > > dblksz="$(_xfs_get_dir_blocksize "$SCRATCH_MNT")"
> > > > > + isize="$(_xfs_get_inode_size "$SCRATCH_MNT")"
> > > > > crc="$(_xfs_has_feature "$SCRATCH_MNT" crc -v)"
> > > > > if [ $crc -eq 1 ]; then
> > > > > leaf_hdr_size=64
> > > > > @@ -226,7 +258,7 @@ _scratch_xfs_populate() {
> > > > >
> > > > > # - BTREE
> > > > > echo "+ btree dir"
> > > > > - __populate_create_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$((128 * dblksz / 40))" true
> > > > > + __populate_xfs_create_btree_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$isize" true
> > > > >
> > > > > # Symlinks
> > > > > # - FMT_LOCAL
> > > > > diff --git a/common/xfs b/common/xfs
> > > > > index 674384a9..7aaa63c7 100644
> > > > > --- a/common/xfs
> > > > > +++ b/common/xfs
> > > > > @@ -1487,6 +1487,15 @@ _require_xfsrestore_xflag()
> > > > > _notrun 'xfsrestore does not support -x flag.'
> > > > > }
> > > > >
> > > > > +# Number of bytes reserved for a full inode record, which includes the
> > > > > +# immediate fork areas.
> > > > > +_xfs_get_inode_size()
> > > > > +{
> > > > > + local mntpoint="$1"
> > > > > +
> > > > > + $XFS_INFO_PROG "$mntpoint" | sed -n '/meta-data=.*isize/s/^.*isize=\([0-9]*\).*$/\1/p'
> > > > > +}
> > > > > +
> > > > > # Number of bytes reserved for only the inode record, excluding the
> > > > > # immediate fork areas.
> > > > > _xfs_get_inode_core_bytes()
> > > > > --
> > > > > 2.18.4
> > > > >
> > > >
> > >
> >
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH V5 2/2] common/populate: Ensure that S_IFDIR.FMT_BTREE is in btree format
2022-12-11 11:23 ` Zorro Lang
@ 2022-12-11 19:19 ` Darrick J. Wong
0 siblings, 0 replies; 10+ messages in thread
From: Darrick J. Wong @ 2022-12-11 19:19 UTC (permalink / raw)
To: Zorro Lang; +Cc: Ziyang Zhang, fstests, linux-xfs, hsiangkao
On Sun, Dec 11, 2022 at 07:23:31PM +0800, Zorro Lang wrote:
> On Sun, Dec 11, 2022 at 07:01:25PM +0800, Zorro Lang wrote:
> > On Sat, Dec 10, 2022 at 06:30:10PM -0800, Darrick J. Wong wrote:
> > > On Sat, Dec 10, 2022 at 09:57:24PM +0800, Zorro Lang wrote:
> > > > On Fri, Dec 09, 2022 at 08:37:41AM -0800, Darrick J. Wong wrote:
> > > > > On Thu, Dec 08, 2022 at 03:28:43PM +0800, Ziyang Zhang wrote:
> > > > > > Sometimes "$((128 * dblksz / 40))" dirents cannot make sure that
> > > > > > S_IFDIR.FMT_BTREE could become btree format for its DATA fork.
> > > > > >
> > > > > > Actually we just observed it can fail after apply our inode
> > > > > > extent-to-btree workaround. The root cause is that the kernel may be
> > > > > > too good at allocating consecutive blocks so that the data fork is
> > > > > > still in extents format.
> > > > > >
> > > > > > Therefore instead of using a fixed number, let's make sure the number
> > > > > > of extents is large enough than (inode size - inode core size) /
> > > > > > sizeof(xfs_bmbt_rec_t).
> > > > > >
> > > > > > Reviewed-by: Zorro Lang <zlang@redhat.com>
> > > > > > Reviewed-by: Allison Henderson <allison.henderson@oracle.com>
> > > > > > Suggested-by: "Darrick J. Wong" <djwong@kernel.org>
> > > > > > Signed-off-by: Gao Xiang <hsiangkao@linux.alibaba.com>
> > > > > > Signed-off-by: Ziyang Zhang <ZiyangZhang@linux.alibaba.com>
> > > > > > ---
> > > > > > common/populate | 34 +++++++++++++++++++++++++++++++++-
> > > > > > common/xfs | 9 +++++++++
> > > > > > 2 files changed, 42 insertions(+), 1 deletion(-)
> > > > > >
> > > > > > diff --git a/common/populate b/common/populate
> > > > > > index 6e004997..0d334a13 100644
> > > > > > --- a/common/populate
> > > > > > +++ b/common/populate
> > > > > > @@ -71,6 +71,37 @@ __populate_create_dir() {
> > > > > > done
> > > > > > }
> > > > > >
> > > > > > +# Create a large directory and ensure that it's a btree format
> > > > > > +__populate_xfs_create_btree_dir() {
> > > > > > + local name="$1"
> > > > > > + local isize="$2"
> > > > > > + local missing="$3"
> > > > > > + local icore_size="$(_xfs_inode_core_bytes)"
> > > > >
> > > > > Doesn't this helper require a path argument now?
> > > >
> > > > What kind of "path" argument? I think he copy it from __populate_create_dir(),
> > > > and keep using the "name" as the root path to create files/dir.
> > >
> > > This path argument, from
> > > https://lore.kernel.org/fstests/20221208072843.1866615-2-ZiyangZhang@linux.alibaba.com/T/#u
> > >
> > > +# Number of bytes reserved for only the inode record, excluding the
> > > +# immediate fork areas.
> > > +_xfs_get_inode_core_bytes()
> > > +{
> > > + local dir="$1"
> > > +
> > > + if _xfs_has_feature "$dir" crc; then
> >
> > Oh, sorry I thought you mean __populate_xfs_create_btree_dir() require a path
> > argument...
> >
> > Yes, and this helper's name should be _xfs_get_inode_core_bytes(), not
> > _xfs_inode_core_bytes(). I didn't find _xfs_inode_core_bytes from current
> > fstests. So it should be:
> >
> > local icore_size="$(_xfs_get_inode_core_bytes $SCRATCH_MNT)"
>
> Hmm... wait a moment. The work directory of __populate_xfs_create_btree_dir() is
> "local name=$1", but the "$name" maybe not a mountpoint.
>
> So we need to get the fs dev/mnt before calling _xfs_get_inode_core_bytes:
>
> local icore_size="$(_xfs_get_inode_core_bytes `_df_dir $name | awk '{print $1}'`)"
>
> Or use $TEST_MNT directly?
The __populate* functions only modify the scratch filesystem, so your
original suggestion is correct:
local icore_size="$(_xfs_get_inode_core_bytes $SCRATCH_MNT)"
--D
> Thanks,
> Zorro
>
> >
> > Hi Ziyang,
> >
> > Please modify this place, and check all other places which call
> > _xfs_get_inode_core_bytes and _xfs_get_inode_size, to make sure
> > they're all changed correctly.
> >
> > Thanks,
> > Zorro
> >
> >
> > >
> > > --D
> > >
> > > > >
> > > > > --D
> > > > >
> > > > > > + # We need enough extents to guarantee that the data fork is in
> > > > > > + # btree format. Cycling the mount to use xfs_db is too slow, so
> > > > > > + # watch for when the extent count exceeds the space after the
> > > > > > + # inode core.
> > > > > > + local max_nextents="$(((isize - icore_size) / 16))"
> > > > > > + local nr=0
> > > > > > +
> > > > > > + mkdir -p "${name}"
> > > > > > + while true; do
> > > > > > + local creat=mkdir
> > > > > > + test "$((nr % 20))" -eq 0 && creat=touch
> > > > > > + $creat "${name}/$(printf "%.08d" "$nr")"
> > > > > > + if [ "$((nr % 40))" -eq 0 ]; then
> > > > > > + local nextents="$(_xfs_get_fsxattr nextents $name)"
> > > > > > + [ $nextents -gt $max_nextents ] && break
> > > > > > + fi
> > > > > > + nr=$((nr+1))
> > > > > > + done
> > > > > > +
> > > > > > + test -z "${missing}" && return
> > > > > > + seq 1 2 "${nr}" | while read d; do
> > > > > > + rm -rf "${name}/$(printf "%.08d" "$d")"
> > > > > > + done
> > > > > > +}
> > > > > > +
> > > > > > # Add a bunch of attrs to a file
> > > > > > __populate_create_attr() {
> > > > > > name="$1"
> > > > > > @@ -176,6 +207,7 @@ _scratch_xfs_populate() {
> > > > > >
> > > > > > blksz="$(stat -f -c '%s' "${SCRATCH_MNT}")"
> > > > > > dblksz="$(_xfs_get_dir_blocksize "$SCRATCH_MNT")"
> > > > > > + isize="$(_xfs_get_inode_size "$SCRATCH_MNT")"
> > > > > > crc="$(_xfs_has_feature "$SCRATCH_MNT" crc -v)"
> > > > > > if [ $crc -eq 1 ]; then
> > > > > > leaf_hdr_size=64
> > > > > > @@ -226,7 +258,7 @@ _scratch_xfs_populate() {
> > > > > >
> > > > > > # - BTREE
> > > > > > echo "+ btree dir"
> > > > > > - __populate_create_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$((128 * dblksz / 40))" true
> > > > > > + __populate_xfs_create_btree_dir "${SCRATCH_MNT}/S_IFDIR.FMT_BTREE" "$isize" true
> > > > > >
> > > > > > # Symlinks
> > > > > > # - FMT_LOCAL
> > > > > > diff --git a/common/xfs b/common/xfs
> > > > > > index 674384a9..7aaa63c7 100644
> > > > > > --- a/common/xfs
> > > > > > +++ b/common/xfs
> > > > > > @@ -1487,6 +1487,15 @@ _require_xfsrestore_xflag()
> > > > > > _notrun 'xfsrestore does not support -x flag.'
> > > > > > }
> > > > > >
> > > > > > +# Number of bytes reserved for a full inode record, which includes the
> > > > > > +# immediate fork areas.
> > > > > > +_xfs_get_inode_size()
> > > > > > +{
> > > > > > + local mntpoint="$1"
> > > > > > +
> > > > > > + $XFS_INFO_PROG "$mntpoint" | sed -n '/meta-data=.*isize/s/^.*isize=\([0-9]*\).*$/\1/p'
> > > > > > +}
> > > > > > +
> > > > > > # Number of bytes reserved for only the inode record, excluding the
> > > > > > # immediate fork areas.
> > > > > > _xfs_get_inode_core_bytes()
> > > > > > --
> > > > > > 2.18.4
> > > > > >
> > > > >
> > > >
> > >
>
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH V5 2/2] common/populate: Ensure that S_IFDIR.FMT_BTREE is in btree format
2022-12-11 11:01 ` Zorro Lang
2022-12-11 11:23 ` Zorro Lang
@ 2022-12-12 3:43 ` Ziyang Zhang
1 sibling, 0 replies; 10+ messages in thread
From: Ziyang Zhang @ 2022-12-12 3:43 UTC (permalink / raw)
To: Zorro Lang; +Cc: fstests, linux-xfs, hsiangkao, Darrick J. Wong
On 2022/12/11 19:01, Zorro Lang wrote:
> Yes, and this helper's name should be _xfs_get_inode_core_bytes(), not
> _xfs_inode_core_bytes(). I didn't find _xfs_inode_core_bytes from current
> fstests. So it should be:
>
> local icore_size="$(_xfs_get_inode_core_bytes $SCRATCH_MNT)"
>
> Hi Ziyang,
>
> Please modify this place, and check all other places which call
> _xfs_get_inode_core_bytes and _xfs_get_inode_size, to make sure
> they're all changed correctly.
>
> Thanks,
> Zorro
Hi Zorro,
You are correct. Sorry for my mistake.
I should use _xfs_get_inode_core_bytes here and add a path
argument($SCRATCH_MNT). I will send a new version.
Regards,
Zhang
^ permalink raw reply [flat|nested] 10+ messages in thread
end of thread, other threads:[~2022-12-12 3:43 UTC | newest]
Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-12-08 7:28 [PATCH V5 0/2] cleanup and bugfix for xfs tests related to btree format Ziyang Zhang
2022-12-08 7:28 ` [PATCH V5 1/2] common/xfs: Add a helper to export inode core size Ziyang Zhang
2022-12-08 7:28 ` [PATCH V5 2/2] common/populate: Ensure that S_IFDIR.FMT_BTREE is in btree format Ziyang Zhang
2022-12-09 16:37 ` Darrick J. Wong
2022-12-10 13:57 ` Zorro Lang
2022-12-11 2:30 ` Darrick J. Wong
2022-12-11 11:01 ` Zorro Lang
2022-12-11 11:23 ` Zorro Lang
2022-12-11 19:19 ` Darrick J. Wong
2022-12-12 3:43 ` Ziyang Zhang
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox