mbox series

[v7,0/2] ceph: fix blindly expanding the readahead windows

Message ID 20230605072109.1027246-1-xiubli@redhat.com
Headers show
Series ceph: fix blindly expanding the readahead windows | expand

Message

Xiubo Li June 5, 2023, 7:21 a.m. UTC
From: Xiubo Li <xiubli@redhat.com>

V7:
- two typo fixes.

Xiubo Li (2):
  ceph: add a dedicated private data for netfs rreq
  ceph: fix blindly expanding the readahead windows

 fs/ceph/addr.c  | 85 ++++++++++++++++++++++++++++++++++++++-----------
 fs/ceph/super.h | 13 ++++++++
 2 files changed, 80 insertions(+), 18 deletions(-)

Comments

Milind Changire June 6, 2023, 5:30 a.m. UTC | #1
Looks good to me.

Reviewed-by: Milind Changire <mchangir@redhat.com>

On Mon, Jun 5, 2023 at 12:53 PM <xiubli@redhat.com> wrote:
>
> From: Xiubo Li <xiubli@redhat.com>
>
> We need to save the 'f_ra.ra_pages' to expand the readahead window
> later.
>
> Cc: stable@vger.kernel.org
> Fixes: 49870056005c ("ceph: convert ceph_readpages to ceph_readahead")
> URL: https://lore.kernel.org/ceph-devel/20230504082510.247-1-sehuww@mail.scut.edu.cn
> URL: https://www.spinics.net/lists/ceph-users/msg76183.html
> Cc: Hu Weiwen <sehuww@mail.scut.edu.cn>
> Reviewed-by: Hu Weiwen <sehuww@mail.scut.edu.cn>
> Tested-by: Hu Weiwen <sehuww@mail.scut.edu.cn>
> Signed-off-by: Xiubo Li <xiubli@redhat.com>
> ---
>  fs/ceph/addr.c  | 45 ++++++++++++++++++++++++++++++++++-----------
>  fs/ceph/super.h | 13 +++++++++++++
>  2 files changed, 47 insertions(+), 11 deletions(-)
>
> diff --git a/fs/ceph/addr.c b/fs/ceph/addr.c
> index 3b20873733af..93fff1a7373f 100644
> --- a/fs/ceph/addr.c
> +++ b/fs/ceph/addr.c
> @@ -404,18 +404,28 @@ static int ceph_init_request(struct netfs_io_request *rreq, struct file *file)
>  {
>         struct inode *inode = rreq->inode;
>         int got = 0, want = CEPH_CAP_FILE_CACHE;
> +       struct ceph_netfs_request_data *priv;
>         int ret = 0;
>
>         if (rreq->origin != NETFS_READAHEAD)
>                 return 0;
>
> +       priv = kzalloc(sizeof(*priv), GFP_NOFS);
> +       if (!priv)
> +               return -ENOMEM;
> +
>         if (file) {
>                 struct ceph_rw_context *rw_ctx;
>                 struct ceph_file_info *fi = file->private_data;
>
> +               priv->file_ra_pages = file->f_ra.ra_pages;
> +               priv->file_ra_disabled = file->f_mode & FMODE_RANDOM;
> +
>                 rw_ctx = ceph_find_rw_context(fi);
> -               if (rw_ctx)
> +               if (rw_ctx) {
> +                       rreq->netfs_priv = priv;
>                         return 0;
> +               }
>         }
>
>         /*
> @@ -425,27 +435,40 @@ static int ceph_init_request(struct netfs_io_request *rreq, struct file *file)
>         ret = ceph_try_get_caps(inode, CEPH_CAP_FILE_RD, want, true, &got);
>         if (ret < 0) {
>                 dout("start_read %p, error getting cap\n", inode);
> -               return ret;
> +               goto out;
>         }
>
>         if (!(got & want)) {
>                 dout("start_read %p, no cache cap\n", inode);
> -               return -EACCES;
> +               ret = -EACCES;
> +               goto out;
> +       }
> +       if (ret == 0) {
> +               ret = -EACCES;
> +               goto out;
>         }
> -       if (ret == 0)
> -               return -EACCES;
>
> -       rreq->netfs_priv = (void *)(uintptr_t)got;
> -       return 0;
> +       priv->caps = got;
> +       rreq->netfs_priv = priv;
> +
> +out:
> +       if (ret < 0)
> +               kfree(priv);
> +
> +       return ret;
>  }
>
>  static void ceph_netfs_free_request(struct netfs_io_request *rreq)
>  {
> -       struct ceph_inode_info *ci = ceph_inode(rreq->inode);
> -       int got = (uintptr_t)rreq->netfs_priv;
> +       struct ceph_netfs_request_data *priv = rreq->netfs_priv;
> +
> +       if (!priv)
> +               return;
>
> -       if (got)
> -               ceph_put_cap_refs(ci, got);
> +       if (priv->caps)
> +               ceph_put_cap_refs(ceph_inode(rreq->inode), priv->caps);
> +       kfree(priv);
> +       rreq->netfs_priv = NULL;
>  }
>
>  const struct netfs_request_ops ceph_netfs_ops = {
> diff --git a/fs/ceph/super.h b/fs/ceph/super.h
> index a226d36b3ecb..3a24b7974d46 100644
> --- a/fs/ceph/super.h
> +++ b/fs/ceph/super.h
> @@ -470,6 +470,19 @@ struct ceph_inode_info {
>  #endif
>  };
>
> +struct ceph_netfs_request_data {
> +       int caps;
> +
> +       /*
> +        * Maximum size of a file readahead request.
> +        * The fadvise could update the bdi's default ra_pages.
> +        */
> +       unsigned int file_ra_pages;
> +
> +       /* Set it if fadvise disables file readahead entirely */
> +       bool file_ra_disabled;
> +};
> +
>  static inline struct ceph_inode_info *
>  ceph_inode(const struct inode *inode)
>  {
> --
> 2.40.1
>