[Libguestfs] [PATCH libnbd 1/2] nbdcopy: Do not use trim for zeroing

Nir Soffer nirsof at gmail.com
Mon Feb 22 12:12:55 UTC 2021


On Mon, Feb 22, 2021, 13:39 Richard W.M. Jones <rjones at redhat.com> wrote:

> The patch doesn't compile for me:
>
> pipe-ops.c:121:17: error: initialization of ‘_Bool (*)(struct rw *,
> uint64_t,  uint64_t,  _Bool)’ {aka ‘_Bool (*)(struct rw *, long unsigned
> int,  long unsigned int,  _Bool)’} from incompatible pointer type ‘_Bool
> (*)(struct rw *, uint64_t,  uint64_t)’ {aka ‘_Bool (*)(struct rw *, long
> unsigned int,  long unsigned int)’} [-Werror=incompatible-pointer-types]
>   121 |   .synch_zero = pipe_synch_trim_zero,
>       |                 ^~~~~~~~~~~~~~~~~~~~
> pipe-ops.c:121:17: note: (near initialization for ‘pipe_ops.synch_zero’)
> pipe-ops.c:133:18: error: initialization of ‘_Bool (*)(struct rw *, struct
> command *, nbd_completion_callback,  _Bool)’ from incompatible pointer type
> ‘_Bool (*)(struct rw *, struct command *, nbd_completion_callback)’
> [-Werror=incompatible-pointer-types]
>   133 |   .asynch_zero = pipe_asynch_trim_zero,
>       |                  ^~~~~~~~~~~~~~~~~~~~~
> pipe-ops.c:133:18: note: (near initialization for ‘pipe_ops.asynch_zero’)
>

It compiled here on top of master, will check again.


> More comments below.
>
> On Sun, Feb 21, 2021 at 03:09:05AM +0200, Nir Soffer wrote:
> > diff --git a/copy/file-ops.c b/copy/file-ops.c
> > index 2a239d0..d0b9447 100644
> > --- a/copy/file-ops.c
> > +++ b/copy/file-ops.c
> > @@ -100,10 +100,9 @@ file_synch_write (struct rw *rw,
> >  }
> >
> >  static bool
> > -file_synch_trim (struct rw *rw, uint64_t offset, uint64_t count)
> > +file_punch_hole(int fd, uint64_t offset, uint64_t count)
>
> (Style) missing space before '(' ...
>

Sorry, will fix in next version.


> >  {
> >  #ifdef FALLOC_FL_PUNCH_HOLE
> > -  int fd = rw->u.local.fd;
> >    int r;
> >
> >    r = fallocate (fd, FALLOC_FL_PUNCH_HOLE | FALLOC_FL_KEEP_SIZE,
> > @@ -113,17 +112,14 @@ file_synch_trim (struct rw *rw, uint64_t offset,
> uint64_t count)
> >      exit (EXIT_FAILURE);
> >    }
> >    return true;
> > -#else /* !FALLOC_FL_PUNCH_HOLE */
> > -  return false;
> >  #endif
> > +  return false;
> >  }
> >
> >  static bool
> > -file_synch_zero (struct rw *rw, uint64_t offset, uint64_t count)
> > +file_zero_range(int fd, uint64_t offset, uint64_t count)
>
> ... and here
>
> >  {
> > -  if (S_ISREG (rw->u.local.stat.st_mode)) {
> >  #ifdef FALLOC_FL_ZERO_RANGE
> > -    int fd = rw->u.local.fd;
> >      int r;
> >
> >      r = fallocate (fd, FALLOC_FL_ZERO_RANGE, offset, count);
> > @@ -133,11 +129,13 @@ file_synch_zero (struct rw *rw, uint64_t offset,
> uint64_t count)
> >      }
> >      return true;
> >  #endif
> > -  }
> > -  else if (S_ISBLK (rw->u.local.stat.st_mode) &&
> > -           IS_ALIGNED (offset | count, rw->u.local.sector_size)) {
> > +  return false;
> > +}
> > +
> > +static bool
> > +file_zeroout(int fd, uint64_t offset, uint64_t count)
>
> ... and here
>
> > +{
> >  #ifdef BLKZEROOUT
> > -    int fd = rw->u.local.fd;
> >      int r;
> >      uint64_t range[2] = {offset, count};
> >
> > @@ -148,6 +146,31 @@ file_synch_zero (struct rw *rw, uint64_t offset,
> uint64_t count)
> >      }
> >      return true;
> >  #endif
> > +    return false;
> > +}
> > +
> > +static bool
> > +file_synch_trim (struct rw *rw, uint64_t offset, uint64_t count)
> > +{
> > +  return file_punch_hole(rw->u.local.fd, offset, count);
> > +}
> > +
> > +static bool
> > +file_synch_zero (struct rw *rw, uint64_t offset, uint64_t count, bool
> allocate)
>
> ... and overlong line.
>
> > +{
> > +  int fd = rw->u.local.fd;
> > +
> > +  if (S_ISREG (rw->u.local.stat.st_mode)) {
> > +    if (allocate) {
> > +        return file_zero_range (fd, offset, count);
> > +    } else {
> > +        return file_punch_hole (fd, offset, count);
> > +    }
> > +  }
> > +  else if (S_ISBLK (rw->u.local.stat.st_mode) &&
> > +           IS_ALIGNED (offset | count, rw->u.local.sector_size)) {
> > +    /* Always allocate, discard and gurantee zeroing. */
> > +    return file_zeroout (fd, offset, count);
> >    }
> >    return false;
>
> In the S_ISBLK && not aligned case, is giving up OK?
>

Not sure what do you mean by this, but it returns false love ke the
previous version, right?


> > diff --git a/copy/nbdcopy.h b/copy/nbdcopy.h
> > index 69fac2a..21d09bf 100644
> > --- a/copy/nbdcopy.h
> > +++ b/copy/nbdcopy.h
> > @@ -134,7 +134,8 @@ struct rw_ops {
> >    bool (*synch_trim) (struct rw *rw, uint64_t offset, uint64_t count);
> >
> >    /* Synchronously zero.  If not possible, returns false. */
> > -  bool (*synch_zero) (struct rw *rw, uint64_t offset, uint64_t count);
> > +  bool (*synch_zero) (struct rw *rw, uint64_t offset, uint64_t count,
> > +                      bool allocate);
>
> After this change ops->synch_trim and ops->asynch_trim are no longer
> used, so I guess they should be removed completely from the code?
>

Yes, unless we have a reason to keep the trim option.


> Rich.
>
> --
> Richard Jones, Virtualization Group, Red Hat
> http://people.redhat.com/~rjones
> Read my programming and virtualization blog: http://rwmj.wordpress.com
> virt-builder quickly builds VMs from scratch
> http://libguestfs.org/virt-builder.1.html
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://listman.redhat.com/archives/libguestfs/attachments/20210222/b13e44dd/attachment.htm>


More information about the Libguestfs mailing list