On 07/24/2014 03:42 AM, Ilya Dryomov wrote:
> Make /sys/bus/rbd/devices/<id>/parent show the entire chain of parent
> images.  While at it, kernel sprintf() doesn't return negative values,
> casting to unsigned long long is no longer necessary and there is no
> good reason to split into multiple sprintf() calls.

I like the use of a single snprintf() call, it is much less
cumbersome.

The reason I always cast u64 values to (unsigned long long)
in printf() calls is because on some 64-bit architectures,
u64 is defined as simply (unsigned long), so without the
cast they spit out warnings.  I hate this, but it is reality
(see include/asm-generic/{int-l64.h,int-ll64.h}).  You can
alternatively use %PRIu64 rather than %llu in your format
strings, but I think I hate that more.  Anyway, if you want
to avoid warnings on all architectures you should fix that.

As another aside, I've been too timid to use the ?: conditional
expression without its middle operand.  I have no objection
to it at all, I like it.  I bring it up because I recently
got burned for using a gcc feature that wasn't supported
on older compilers (unnamed struct/union fields)--specifically
a version newer than gcc 3.2, which is the minimum supported
version for the kernel (see Documentation/Changes).

But fear not!  That extension is supported in gcc 3.2:

https://gcc.gnu.org/onlinedocs/gcc-3.2/gcc/Conditionals.html#Conditionals
Just FYI...

Reviewed-by: Alex Elder <[email protected]>

> Signed-off-by: Ilya Dryomov <[email protected]>
> ---
>  Documentation/ABI/testing/sysfs-bus-rbd |    4 +--
>  drivers/block/rbd.c                     |   56 
> +++++++++++++------------------
>  2 files changed, 25 insertions(+), 35 deletions(-)
> 
> diff --git a/Documentation/ABI/testing/sysfs-bus-rbd 
> b/Documentation/ABI/testing/sysfs-bus-rbd
> index 501adc2a9ec7..2ddd680929d8 100644
> --- a/Documentation/ABI/testing/sysfs-bus-rbd
> +++ b/Documentation/ABI/testing/sysfs-bus-rbd
> @@ -94,5 +94,5 @@ current_snap
>  
>  parent
>  
> -     Information identifying the pool, image, and snapshot id for
> -     the parent image in a layered rbd image (format 2 only).
> +     Information identifying the chain of parent images in a layered rbd
> +     image.  Entries are separated by empty lines.
> diff --git a/drivers/block/rbd.c b/drivers/block/rbd.c
> index 703b728e05fa..7847fbb949ff 100644
> --- a/drivers/block/rbd.c
> +++ b/drivers/block/rbd.c
> @@ -3685,46 +3685,36 @@ static ssize_t rbd_snap_show(struct device *dev,
>  }
>  
>  /*
> - * For an rbd v2 image, shows the pool id, image id, and snapshot id
> - * for the parent image.  If there is no parent, simply shows
> - * "(no parent image)".
> + * For a v2 image, shows the chain of parent images, separated by empty
> + * lines.  For v1 images or if there is no parent, shows "(no parent
> + * image)".
>   */
>  static ssize_t rbd_parent_show(struct device *dev,
> -                          struct device_attribute *attr,
> -                          char *buf)
> +                            struct device_attribute *attr,
> +                            char *buf)
>  {
>       struct rbd_device *rbd_dev = dev_to_rbd_dev(dev);
> -     struct rbd_spec *spec = rbd_dev->parent_spec;
> -     int count;
> -     char *bufp = buf;
> +     ssize_t count = 0;
>  
> -     if (!spec)
> +     if (!rbd_dev->parent)
>               return sprintf(buf, "(no parent image)\n");
>  
> -     count = sprintf(bufp, "pool_id %llu\npool_name %s\n",
> -                     (unsigned long long) spec->pool_id, spec->pool_name);
> -     if (count < 0)
> -             return count;
> -     bufp += count;
> -
> -     count = sprintf(bufp, "image_id %s\nimage_name %s\n", spec->image_id,
> -                     spec->image_name ? spec->image_name : "(unknown)");
> -     if (count < 0)
> -             return count;
> -     bufp += count;
> -
> -     count = sprintf(bufp, "snap_id %llu\nsnap_name %s\n",
> -                     (unsigned long long) spec->snap_id, spec->snap_name);
> -     if (count < 0)
> -             return count;
> -     bufp += count;
> -
> -     count = sprintf(bufp, "overlap %llu\n", rbd_dev->parent_overlap);
> -     if (count < 0)
> -             return count;
> -     bufp += count;
> -
> -     return (ssize_t) (bufp - buf);
> +     for ( ; rbd_dev->parent; rbd_dev = rbd_dev->parent) {
> +             struct rbd_spec *spec = rbd_dev->parent_spec;
> +
> +             count += sprintf(&buf[count], "%s"
> +                         "pool_id %llu\npool_name %s\n"
> +                         "image_id %s\nimage_name %s\n"
> +                         "snap_id %llu\nsnap_name %s\n"
> +                         "overlap %llu\n",
> +                         !count ? "" : "\n", /* first? */
> +                         spec->pool_id, spec->pool_name,
> +                         spec->image_id, spec->image_name ?: "(unknown)",
> +                         spec->snap_id, spec->snap_name,
> +                         rbd_dev->parent_overlap);
> +     }
> +
> +     return count;
>  }
>  
>  static ssize_t rbd_image_refresh(struct device *dev,
> 

--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to