From: Eryu Guan <guaneryu@gmail.com>
To: "Darrick J. Wong" <darrick.wong@oracle.com>
Cc: fstests <fstests@vger.kernel.org>,
xfs <linux-xfs@vger.kernel.org>,
Ross Zwisler <ross.zwisler@linux.intel.com>
Subject: Re: [PATCH] generic/223: port t_stripealign to FIEMAP
Date: Fri, 15 Jun 2018 10:49:01 +0800 [thread overview]
Message-ID: <20180615024901.GF2780@desktop> (raw)
In-Reply-To: <20180613225057.GB9432@magnolia>
On Wed, Jun 13, 2018 at 03:50:57PM -0700, Darrick J. Wong wrote:
> From: Darrick J. Wong <darrick.wong@oracle.com>
>
> Since XFS has deprecated FIBMAP on FSDAX filesystems, we can't use
> FIBMAP to verify stripe alignment anymore. FIEMAP has existed for quite
> some time now, so port it to use that instead, and only fall back to
> FIBMAP if FIEMAP doesn't exist.
>
> Tested-by: ross.zwisler@linux.intel.com
> Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
> ---
> src/t_stripealign.c | 72 +++++++++++++++++++++++++++++++++++++++++++--------
> 1 file changed, 61 insertions(+), 11 deletions(-)
>
> diff --git a/src/t_stripealign.c b/src/t_stripealign.c
> index 05ed36b5..690f743a 100644
> --- a/src/t_stripealign.c
> +++ b/src/t_stripealign.c
> @@ -17,8 +17,13 @@
> #include <fcntl.h>
> #include <stdio.h>
> #include <sys/ioctl.h>
> +#include <linux/fiemap.h>
> +#include <linux/fs.h>
As it requires <linux/fiemap.h> now, looks like we should update
src/Makefile too to only compile it when "HAVE_FIEMAP" is true.
ifeq ($(HAVE_FIEMAP), true)
LINUX_TARGETS += fiemap-tester t_stripealign
endif
Thanks,
Eryu
P.S.
LINUX_TARGETS could be cleaned up and merged with TARGETS, it's useless
to have both TARGETS and LINUX_TARGETS defined now, as we only support
Linux platform, but that's a different issue.
>
> -#define FIBMAP _IO(0x00, 1) /* bmap access */
> +#define FIEMAP_EXTENT_ACCEPTABLE (FIEMAP_EXTENT_LAST | \
> + FIEMAP_EXTENT_DATA_ENCRYPTED | FIEMAP_EXTENT_ENCODED | \
> + FIEMAP_EXTENT_UNWRITTEN | FIEMAP_EXTENT_MERGED | \
> + FIEMAP_EXTENT_SHARED)
>
> /*
> * If only filename given, print first block.
> @@ -28,11 +33,14 @@
>
> int main(int argc, char ** argv)
> {
> - int fd;
> - int ret;
> - int sunit = 0; /* in blocks */
> - char *filename;
> - unsigned int block = 0;
> + struct stat sb;
> + struct fiemap *fie;
> + struct fiemap_extent *fe;
> + int fd;
> + int ret;
> + int sunit = 0; /* in blocks */
> + char *filename;
> + unsigned long long block;
>
> if (argc < 3) {
> printf("Usage: %s <filename> <sunit in blocks>\n", argv[0]);
> @@ -48,21 +56,63 @@ int main(int argc, char ** argv)
> return 1;
> }
>
> - ret = ioctl(fd, FIBMAP, &block);
> - if (ret < 0) {
> + ret = fstat(fd, &sb);
> + if (ret) {
> + perror(filename);
> close(fd);
> - perror("fibmap");
> return 1;
> }
>
> - close(fd);
> + fie = calloc(1, sizeof(struct fiemap) + sizeof(struct fiemap_extent));
> + if (!fie) {
> + close(fd);
> + perror("malloc");
> + return 1;
> + }
> + fie->fm_length = 1;
> + fie->fm_flags = FIEMAP_FLAG_SYNC;
> + fie->fm_extent_count = 1;
> +
> + ret = ioctl(fd, FS_IOC_FIEMAP, fie);
> + if (ret < 0) {
> + unsigned int bmap = 0;
> +
> + ret = ioctl(fd, FIBMAP, &bmap);
> + if (ret < 0) {
> + perror("fibmap");
> + free(fie);
> + close(fd);
> + return 1;
> + }
> + block = bmap;
> + goto check;
> + }
>
> +
> + if (fie->fm_mapped_extents != 1) {
> + printf("%s: no extents?\n", filename);
> + free(fie);
> + close(fd);
> + return 1;
> + }
> + fe = &fie->fm_extents[0];
> + if (fe->fe_flags & ~FIEMAP_EXTENT_ACCEPTABLE) {
> + printf("%s: bad flags 0x%x\n", filename, fe->fe_flags);
> + free(fie);
> + close(fd);
> + return 1;
> + }
> +
> + block = fie->fm_extents[0].fe_physical / sb.st_blksize;
> +check:
> if (block % sunit) {
> - printf("%s: Start block %u not multiple of sunit %u\n",
> + printf("%s: Start block %llu not multiple of sunit %u\n",
> filename, block, sunit);
> return 1;
> } else
> printf("%s: well-aligned\n", filename);
> + free(fie);
> + close(fd);
>
> return 0;
> }
next prev parent reply other threads:[~2018-06-15 2:49 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-06-13 22:50 [PATCH] generic/223: port t_stripealign to FIEMAP Darrick J. Wong
2018-06-15 2:49 ` Eryu Guan [this message]
2018-06-17 14:39 ` Eryu Guan
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=20180615024901.GF2780@desktop \
--to=guaneryu@gmail.com \
--cc=darrick.wong@oracle.com \
--cc=fstests@vger.kernel.org \
--cc=linux-xfs@vger.kernel.org \
--cc=ross.zwisler@linux.intel.com \
/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).