[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20220825155918.00000d42@huawei.com>
Date: Thu, 25 Aug 2022 15:59:18 +0100
From: Jonathan Cameron <Jonathan.Cameron@...wei.com>
To: <ira.weiny@...el.com>
CC: Dan Williams <dan.j.williams@...el.com>,
Bjorn Helgaas <bhelgaas@...gle.com>,
Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
Alison Schofield <alison.schofield@...el.com>,
Vishal Verma <vishal.l.verma@...el.com>,
Ben Widawsky <bwidawsk@...nel.org>,
<linux-cxl@...r.kernel.org>, <linux-kernel@...r.kernel.org>,
<linux-pci@...r.kernel.org>
Subject: Re: [PATCH V2 2/2] cxl/doe: Request exclusive DOE access
On Wed, 24 Aug 2022 16:24:50 -0700
ira.weiny@...el.com wrote:
> From: Ira Weiny <ira.weiny@...el.com>
>
> The PCIE Data Object Exchange (DOE) mailbox is a protocol run over
> configuration cycles. It assumes one initiator at a time. While the
> kernel has control of the mailbox user space writes could interfere with
> the kernel access.
>
> Mark DOE mailbox config space exclusive when iterated by the CXL driver.
>
> Signed-off-by: Ira Weiny <ira.weiny@...el.com>
> ---
> drivers/cxl/pci.c | 5 +++++
> include/uapi/linux/pci_regs.h | 1 +
> 2 files changed, 6 insertions(+)
>
> diff --git a/drivers/cxl/pci.c b/drivers/cxl/pci.c
> index faeb5d9d7a7a..5b833eb91543 100644
> --- a/drivers/cxl/pci.c
> +++ b/drivers/cxl/pci.c
> @@ -418,6 +418,11 @@ static void devm_cxl_pci_create_doe(struct cxl_dev_state *cxlds)
> continue;
> }
>
> + if (!pci_request_config_region_exclusive(pdev, off,
> + PCI_DOE_CAP_SIZE,
> + dev_name(dev)))
> + pci_err(pdev, "Failed to exclude DOE registers\n");
> +
> if (xa_insert(&cxlds->doe_mbs, off, doe_mb, GFP_KERNEL)) {
> dev_err(dev, "xa_insert failed to insert MB @ %x\n",
> off);
> diff --git a/include/uapi/linux/pci_regs.h b/include/uapi/linux/pci_regs.h
> index 57b8e2ffb1dd..f2396bcd09cc 100644
> --- a/include/uapi/linux/pci_regs.h
> +++ b/include/uapi/linux/pci_regs.h
> @@ -1119,6 +1119,7 @@
> #define PCI_DOE_STATUS_DATA_OBJECT_READY 0x80000000 /* Data Object Ready */
> #define PCI_DOE_WRITE 0x10 /* DOE Write Data Mailbox Register */
> #define PCI_DOE_READ 0x14 /* DOE Read Data Mailbox Register */
> +#define PCI_DOE_CAP_SIZE (0x14 + 4) /* Size of this register block */
Equivalents in this file don't build _SIZE from previous register - they just
give it directly. Hence change this to 0x18.
Also, it seems that _SIZEOF is the common naming for this in this file.
There are a few _SIZE such as PCI_MSIX_ENTRY_SIZE but many more _SIZEOF
>
> /* DOE Data Object - note not actually registers */
> #define PCI_DOE_DATA_OBJECT_HEADER_1_VID 0x0000ffff
Powered by blists - more mailing lists