On May 15, 2017, at 11:07, Davidlohr Bueso <d...@stgolabs.net> wrote:
> 
> This replaces the in-house version, which is also derived
> from Jan's interval tree implementation.
> 
> Cc: oleg.dro...@intel.com
> Cc: andreas.dil...@intel.com
> Cc: jsimm...@infradead.org
> Cc: lustre-de...@lists.lustre.org
> Signed-off-by: Davidlohr Bueso <dbu...@suse.de>

Repeating my request that the whole patch series should be CC'd to the 
linux-fsdevel list,
since I only got this last patch and this makes it difficult to review the 
whole series.

> ---
> diff --git a/drivers/staging/lustre/lustre/llite/file.c 
> b/drivers/staging/lustre/lustre/llite/file.c
> index 67c4b9cc6e75..bd020bdaf85d 100644
> --- a/drivers/staging/lustre/lustre/llite/file.c
> +++ b/drivers/staging/lustre/lustre/llite/file.c
> @@ -1083,10 +1083,10 @@ ll_file_io_generic(const struct lu_env *env, struct 
> vvp_io_args *args,
>               if (((iot == CIT_WRITE) ||
>                    (iot == CIT_READ && (file->f_flags & O_DIRECT))) &&
>                   !(vio->vui_fd->fd_flags & LL_FILE_GROUP_LOCKED)) {
> -                     CDEBUG(D_VFSTRACE, "Range lock [%llu, %llu]\n",
> -                            range.rl_node.in_extent.start,
> -                            range.rl_node.in_extent.end);
> -                     rc = range_lock(&lli->lli_write_tree, &range);
> +                     CDEBUG(D_VFSTRACE, "Range lock [%lu, %lu]\n",
> +                            range.node.start,
> +                            range.node.last);
> +                     rc = 
> range_write_lock_interruptible(&lli->lli_write_tree, &range);
>                       if (rc < 0)
>                               goto out;
> 
> @@ -1096,10 +1096,10 @@ ll_file_io_generic(const struct lu_env *env, struct 
> vvp_io_args *args,
>               rc = cl_io_loop(env, io);
>               ll_cl_remove(file, env);
>               if (range_locked) {
> -                     CDEBUG(D_VFSTRACE, "Range unlock [%llu, %llu]\n",
> -                            range.rl_node.in_extent.start,
> -                            range.rl_node.in_extent.end);
> -                     range_unlock(&lli->lli_write_tree, &range);
> +                     CDEBUG(D_VFSTRACE, "Range unlock [%lu, %lu]\n",
> +                            range.node.start,
> +                            range.node.last);
> +                     range_write_unlock(&lli->lli_write_tree, &range);
>               }
>       } else {
>               /* cl_io_rw_init() handled IO */

I'm not against this patch, but it does expose an implementation difference 
between the
Lustre version of this code and the in-tree version.  Preferred kernel coding 
style is to
have a struct-unique prefix for struct members (e.g. using "rl_" for struct 
range_lock,
using "in_" for struct interval_tree_node).  That allows tags to work properly, 
instead
of trying to locate generic struct names like "start", "node" etc.

In an unexpected twist of fate, the Lustre version of this code is following 
preferred
coding style and the in-tree (interval_tree) and submitted (range_rwlock) code 
does not.

Cheers, Andreas






Reply via email to