[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH 3/3] raw-posix: add discard support
From: |
Kevin Wolf |
Subject: |
Re: [Qemu-devel] [PATCH 3/3] raw-posix: add discard support |
Date: |
Fri, 17 Dec 2010 11:32:45 +0100 |
User-agent: |
Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.1.15) Gecko/20101027 Fedora/3.0.10-1.fc12 Thunderbird/3.0.10 |
Am 16.12.2010 19:36, schrieb Christoph Hellwig:
> Add support to discard blocks in a raw image residing on an XFS filesystem
> by calling the XFS_IOC_UNRESVSP64 ioctl to punch holes. Support for other
> hole punching mechanisms can be added when they become available.
>
> Signed-off-by: Christoph Hellwig <address@hidden>
>
> Index: qemu/block/raw-posix.c
> ===================================================================
> --- qemu.orig/block/raw-posix.c 2010-12-15 10:05:37.000000000 +0100
> +++ qemu/block/raw-posix.c 2010-12-16 17:40:47.617253460 +0100
> @@ -69,6 +69,10 @@
> #include <sys/diskslice.h>
> #endif
>
> +#ifdef CONFIG_XFS
> +#include <xfs/xfs.h>
> +#endif
> +
> //#define DEBUG_FLOPPY
>
> //#define DEBUG_BLOCK
> @@ -120,6 +124,9 @@ typedef struct BDRVRawState {
> #endif
> uint8_t *aligned_buf;
> unsigned aligned_buf_size;
> +#ifdef CONFIG_XFS
> + bool is_xfs : 1;
> +#endif
> } BDRVRawState;
>
> static int fd_open(BlockDriverState *bs);
> @@ -196,6 +203,12 @@ static int raw_open_common(BlockDriverSt
> #endif
> }
>
> +#ifdef CONFIG_XFS
> + if (platform_test_xfs_fd(s->fd)) {
> + s->is_xfs = 1;
> + }
> +#endif
> +
> return 0;
>
> out_free_buf:
> @@ -740,6 +753,36 @@ static int raw_flush(BlockDriverState *b
> return qemu_fdatasync(s->fd);
> }
>
> +#ifdef CONFIG_XFS
> +static int xfs_discard(BDRVRawState *s, int64_t sector_num, int nb_sectors)
> +{
> + struct xfs_flock64 fl;
> +
> + memset(&fl, 0, sizeof(fl));
> + fl.l_whence = SEEK_SET;
> + fl.l_start = sector_num << 9;
> + fl.l_len = (int64_t)nb_sectors << 9;
> +
> + if (xfsctl(NULL, s->fd, XFS_IOC_UNRESVSP64, &fl) < 0) {
> + printf("cannot punch hole (%s)\n", strerror(errno));
Debugging leftover? Block drivers shouldn't print anything to stdout.
> + return -errno;
> + }
> +
> + return 0;
> +}
> +#endif
> +
> +static int raw_discard(BlockDriverState *bs, int64_t sector_num, int
> nb_sectors)
> +{
> +#ifdef CONFIG_XFS
> + BDRVRawState *s = bs->opaque;
> +
> + if (s->is_xfs)
> + return xfs_discard(s, sector_num, nb_sectors);
Missing braces.
I have already applied patch 1 and 2 to the block branch, so sending a
v5 for this one is enough.
Kevin
- [Qemu-devel] [PATCH 6/7] ide: add TRIM support, (continued)
- [Qemu-devel] [PATCH 6/7] ide: add TRIM support, Christoph Hellwig, 2010/12/10
- [Qemu-devel] [PATCH 7/7] raw-posix: add discard support, Christoph Hellwig, 2010/12/10
- Re: [Qemu-devel] ]PATCH 0/7] add TRIM/UNMAP support, v3, Stefan Hajnoczi, 2010/12/12
- Re: [Qemu-devel] ]PATCH 0/7] add TRIM/UNMAP support, v3, Kevin Wolf, 2010/12/16
- [Qemu-devel] Re: [PATCH 0/3] add TRIM/UNMAP support, v4, Christoph Hellwig, 2010/12/16