[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <77226007-502c-4e80-9ea3-62409a928e17@intel.com>
Date: Wed, 19 Feb 2025 10:12:57 -0700
From: Dave Jiang <dave.jiang@...el.com>
To: Li Ming <ming.li@...omail.com>, dave@...olabs.net,
jonathan.cameron@...wei.com, alison.schofield@...el.com,
vishal.l.verma@...el.com, ira.weiny@...el.com, dan.j.williams@...el.com
Cc: linux-cxl@...r.kernel.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH v2 2/7] cxl/core: cxl_mem_sanitize() cleanup
On 2/17/25 7:48 AM, Li Ming wrote:
> In cxl_mem_sanitize(), the down_read() and up_read() for
> cxl_region_rwsem can be simply replaced by a guard(rwsem_read), and the
> local variable 'rc' can be removed.
>
> Reviewed-by: Jonathan Cameron <Jonathan.Cameron@...wei.com>
> Signed-off-by: Li Ming <ming.li@...omail.com>
Reviewed-by: Dave Jiang <dave.jiang@...el.com>
> ---
> drivers/cxl/core/mbox.c | 10 +++-------
> 1 file changed, 3 insertions(+), 7 deletions(-)
>
> diff --git a/drivers/cxl/core/mbox.c b/drivers/cxl/core/mbox.c
> index 548564c770c0..0601297af0c9 100644
> --- a/drivers/cxl/core/mbox.c
> +++ b/drivers/cxl/core/mbox.c
> @@ -1222,23 +1222,19 @@ int cxl_mem_sanitize(struct cxl_memdev *cxlmd, u16 cmd)
> {
> struct cxl_memdev_state *mds = to_cxl_memdev_state(cxlmd->cxlds);
> struct cxl_port *endpoint;
> - int rc;
>
> /* synchronize with cxl_mem_probe() and decoder write operations */
> guard(device)(&cxlmd->dev);
> endpoint = cxlmd->endpoint;
> - down_read(&cxl_region_rwsem);
> + guard(rwsem_read)(&cxl_region_rwsem);
> /*
> * Require an endpoint to be safe otherwise the driver can not
> * be sure that the device is unmapped.
> */
> if (endpoint && cxl_num_decoders_committed(endpoint) == 0)
> - rc = __cxl_mem_sanitize(mds, cmd);
> - else
> - rc = -EBUSY;
> - up_read(&cxl_region_rwsem);
> + return __cxl_mem_sanitize(mds, cmd);
>
> - return rc;
> + return -EBUSY;
> }
>
> static int add_dpa_res(struct device *dev, struct resource *parent,
Powered by blists - more mailing lists