linux-rdma.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Jonathan Cameron <jonathan.cameron-hv44wF8Li93QT0dZR+AlfA@public.gmane.org>
To: Logan Gunthorpe <logang-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
Cc: "Alex Williamson"
	<alex.williamson-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>,
	linux-nvdimm-hn68Rpc1hR1g9hUCZPvPmw@public.gmane.org,
	linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	linux-pci-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	linux-nvme-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org,
	linux-block-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	"Jérôme Glisse" <jglisse-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>,
	"Jason Gunthorpe" <jgg-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>,
	"Christian König" <christian.koenig-5C7GfCeVMHo@public.gmane.org>,
	"Benjamin Herrenschmidt"
	<benh-XVmvHMARGAS8U2dJNN8I7kB+6BGkLq7r@public.gmane.org>,
	"Bjorn Helgaas"
	<bhelgaas-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>,
	"Max Gurtovoy" <maxg-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>,
	"Christoph Hellwig" <hch-jcswGhMUV9g@public.gmane.org>
Subject: Re: [PATCH v5 01/13] PCI/P2PDMA: Support peer-to-peer memory
Date: Fri, 31 Aug 2018 17:19:06 +0100	[thread overview]
Message-ID: <20180831171906.00002751@huawei.com> (raw)
In-Reply-To: <20180830185352.3369-2-logang-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>

On Thu, 30 Aug 2018 12:53:40 -0600
Logan Gunthorpe <logang-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org> wrote:

> Some PCI devices may have memory mapped in a BAR space that's
> intended for use in peer-to-peer transactions. In order to enable
> such transactions the memory must be registered with ZONE_DEVICE pages
> so it can be used by DMA interfaces in existing drivers.
> 
> Add an interface for other subsystems to find and allocate chunks of P2P
> memory as necessary to facilitate transfers between two PCI peers:
> 
> int pci_p2pdma_add_client();
> struct pci_dev *pci_p2pmem_find();
> void *pci_alloc_p2pmem();
> 
> The new interface requires a driver to collect a list of client devices
> involved in the transaction with the pci_p2pmem_add_client*() functions
> then call pci_p2pmem_find() to obtain any suitable P2P memory. Once
> this is done the list is bound to the memory and the calling driver is
> free to add and remove clients as necessary (adding incompatible clients
> will fail). With a suitable p2pmem device, memory can then be
> allocated with pci_alloc_p2pmem() for use in DMA transactions.
> 
> Depending on hardware, using peer-to-peer memory may reduce the bandwidth
> of the transfer but can significantly reduce pressure on system memory.
> This may be desirable in many cases: for example a system could be designed
> with a small CPU connected to a PCIe switch by a small number of lanes
> which would maximize the number of lanes available to connect to NVMe
> devices.
> 
> The code is designed to only utilize the p2pmem device if all the devices
> involved in a transfer are behind the same PCI bridge. This is because we
> have no way of knowing whether peer-to-peer routing between PCIe Root Ports
> is supported (PCIe r4.0, sec 1.3.1). Additionally, the benefits of P2P
> transfers that go through the RC is limited to only reducing DRAM usage
> and, in some cases, coding convenience. The PCI-SIG may be exploring
> adding a new capability bit to advertise whether this is possible for
> future hardware.
> 
> This commit includes significant rework and feedback from Christoph
> Hellwig.
> 
> Signed-off-by: Christoph Hellwig <hch-jcswGhMUV9g@public.gmane.org>
> Signed-off-by: Logan Gunthorpe <logang-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>

Apologies for being a late entrant to this conversation so I may be asking
about a topic that has been covered in detail in earlier patches!
> ---
...

> +/*
> + * Find the distance through the nearest common upstream bridge between
> + * two PCI devices.
> + *
> + * If the two devices are the same device then 0 will be returned.
> + *
> + * If there are two virtual functions of the same device behind the same
> + * bridge port then 2 will be returned (one step down to the PCIe switch,
> + * then one step back to the same device).
> + *
> + * In the case where two devices are connected to the same PCIe switch, the
> + * value 4 will be returned. This corresponds to the following PCI tree:
> + *
> + *     -+  Root Port
> + *      \+ Switch Upstream Port
> + *       +-+ Switch Downstream Port
> + *       + \- Device A
> + *       \-+ Switch Downstream Port
> + *         \- Device B
> + *
> + * The distance is 4 because we traverse from Device A through the downstream
> + * port of the switch, to the common upstream port, back up to the second
> + * downstream port and then to Device B.
> + *
> + * Any two devices that don't have a common upstream bridge will return -1.
> + * In this way devices on separate PCIe root ports will be rejected, which
> + * is what we want for peer-to-peer seeing each PCIe root port defines a
> + * separate hierarchy domain and there's no way to determine whether the root
> + * complex supports forwarding between them.
> + *
> + * In the case where two devices are connected to different PCIe switches,
> + * this function will still return a positive distance as long as both
> + * switches evenutally have a common upstream bridge. Note this covers
> + * the case of using multiple PCIe switches to achieve a desired level of
> + * fan-out from a root port. The exact distance will be a function of the
> + * number of switches between Device A and Device B.

This feels like a somewhat simplistic starting point rather than a
generally correct estimate to use.  Should we be taking the bandwidth of
those links into account for example, or any discoverable latencies?
Not all PCIe switches are alike - particularly when it comes to P2P.

I guess that can be a topic for future development if it turns out people
have horrible mixed systems.

> + *
> + * If a bridge which has any ACS redirection bits set is in the path
> + * then this functions will return -2. This is so we reject any
> + * cases where the TLPs are forwarded up into the root complex.
> + * In this case, a list of all infringing bridge addresses will be
> + * populated in acs_list (assuming it's non-null) for printk purposes.
> + */

  parent reply	other threads:[~2018-08-31 16:19 UTC|newest]

Thread overview: 58+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-08-30 18:53 [PATCH v5 00/13] Copy Offload in NVMe Fabrics with P2P PCI Memory Logan Gunthorpe
     [not found] ` <20180830185352.3369-1-logang-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
2018-08-30 18:53   ` [PATCH v5 01/13] PCI/P2PDMA: Support peer-to-peer memory Logan Gunthorpe
     [not found]     ` <20180830185352.3369-2-logang-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
2018-08-31  8:04       ` Christian König
     [not found]         ` <2711b3a7-f582-0dda-8ac2-530be7bda1bb-5C7GfCeVMHo@public.gmane.org>
2018-08-31 15:48           ` Logan Gunthorpe
2018-09-01  8:27             ` Christoph Hellwig
2018-08-31 16:19       ` Jonathan Cameron [this message]
     [not found]         ` <20180831171906.00002751-hv44wF8Li93QT0dZR+AlfA@public.gmane.org>
2018-08-31 16:26           ` Logan Gunthorpe
2018-08-30 18:53   ` [PATCH v5 02/13] PCI/P2PDMA: Add sysfs group to display p2pmem stats Logan Gunthorpe
2018-08-30 18:53   ` [PATCH v5 04/13] PCI/P2PDMA: Introduce configfs/sysfs enable attribute helpers Logan Gunthorpe
2018-08-30 18:53   ` [PATCH v5 05/13] docs-rst: Add a new directory for PCI documentation Logan Gunthorpe
2018-08-30 18:53   ` [PATCH v5 06/13] PCI/P2PDMA: Add P2P DMA driver writer's documentation Logan Gunthorpe
2018-08-31  0:34     ` Randy Dunlap
     [not found]       ` <382af881-0ae1-0274-4628-0137071125b1-wEGCiKHe2LqWVfeAwA7xHQ@public.gmane.org>
2018-08-31 15:44         ` Logan Gunthorpe
     [not found]     ` <20180830185352.3369-7-logang-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
2018-08-31  8:08       ` Christian König
     [not found]         ` <98bff500-4e4c-3a34-6762-16ef4b076d90-5C7GfCeVMHo@public.gmane.org>
2018-08-31 15:51           ` Logan Gunthorpe
     [not found]             ` <6820d451-9591-1979-00bf-60c65fc4f136-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
2018-08-31 17:38               ` Christian König
     [not found]                 ` <30411655-9b90-749e-857f-318dac7cccbf-5C7GfCeVMHo@public.gmane.org>
2018-08-31 19:11                   ` Logan Gunthorpe
2018-08-30 18:53   ` [PATCH v5 07/13] block: Add PCI P2P flag for request queue and check support for requests Logan Gunthorpe
     [not found]     ` <20180830185352.3369-8-logang-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
2018-08-30 19:11       ` Jens Axboe
     [not found]         ` <b5ab8fa3-34ac-3117-fa0d-5206c3939435-tSWWG44O7X1aa/9Udqfwiw@public.gmane.org>
2018-08-30 19:17           ` Logan Gunthorpe
     [not found]             ` <7c5b9d2c-d94e-582c-f1d7-0827dbb7df7c-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
2018-08-30 19:19               ` Jens Axboe
2018-09-01  8:28           ` Christoph Hellwig
     [not found]             ` <20180901082812.GB670-jcswGhMUV9g@public.gmane.org>
2018-09-03 22:26               ` Logan Gunthorpe
     [not found]                 ` <5f79c012-c6e1-56bb-62fd-0689181fb2c9-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
2018-09-05 19:26                   ` Jens Axboe
     [not found]                     ` <59b28977-8f2a-6228-2050-03fae6bdbedd-tSWWG44O7X1aa/9Udqfwiw@public.gmane.org>
2018-09-05 19:33                       ` Logan Gunthorpe
2018-09-05 19:45                         ` Jens Axboe
2018-09-05 19:53                           ` Logan Gunthorpe
     [not found]                           ` <09258b9b-3aed-9890-b31a-bd70a133966c-tSWWG44O7X1aa/9Udqfwiw@public.gmane.org>
2018-09-05 19:56                             ` Christoph Hellwig
2018-09-05 19:54                               ` Jens Axboe
     [not found]                                 ` <bcc1b3cf-2fd9-fa61-9cfb-b0e4d84e5d94-tSWWG44O7X1aa/9Udqfwiw@public.gmane.org>
2018-09-05 20:11                                   ` Christoph Hellwig
     [not found]                                     ` <20180905201152.GA1893-jcswGhMUV9g@public.gmane.org>
2018-09-05 20:09                                       ` Logan Gunthorpe
2018-09-05 20:14                                         ` Jens Axboe
     [not found]                                           ` <2a3394bd-5f13-4818-43f4-dfc61f501e05-tSWWG44O7X1aa/9Udqfwiw@public.gmane.org>
2018-09-05 20:18                                             ` Logan Gunthorpe
     [not found]                                               ` <e3ef26e6-6c8d-25b8-fa64-14594a51263c-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
2018-09-05 20:19                                                 ` Jens Axboe
     [not found]                                                   ` <3af4d1d4-da07-c0a6-8464-9ddc1378f2f4-tSWWG44O7X1aa/9Udqfwiw@public.gmane.org>
2018-09-05 20:32                                                     ` Logan Gunthorpe
     [not found]                                                       ` <f9e660cd-b597-bb6e-56a2-82fe71cb3649-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
2018-09-05 20:36                                                         ` Jens Axboe
     [not found]                                                           ` <34d9b2f7-9e6d-4a0a-77e5-ec0e99610f5c-tSWWG44O7X1aa/9Udqfwiw@public.gmane.org>
2018-09-05 21:03                                                             ` Logan Gunthorpe
     [not found]                                                               ` <c41c802c-9235-5383-2dfa-af9c1553f11b-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
2018-09-05 21:13                                                                 ` Christoph Hellwig
2018-09-05 21:18                                                                 ` Jens Axboe
2018-09-10 16:41                                                                 ` Christoph Hellwig
     [not found]                                                                   ` <20180910164144.GA24591-jcswGhMUV9g@public.gmane.org>
2018-09-10 18:11                                                                     ` Logan Gunthorpe
2018-09-11  7:10                                                                       ` Christoph Hellwig
2018-08-30 18:53   ` [PATCH v5 08/13] IB/core: Ensure we map P2P memory correctly in rdma_rw_ctx_[init|destroy]() Logan Gunthorpe
     [not found]     ` <20180830185352.3369-9-logang-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
2018-08-31  0:18       ` Sagi Grimberg
2018-08-30 18:53   ` [PATCH v5 09/13] nvme-pci: Use PCI p2pmem subsystem to manage the CMB Logan Gunthorpe
2018-08-30 18:53   ` [PATCH v5 10/13] nvme-pci: Add support for P2P memory in requests Logan Gunthorpe
2018-09-04 15:16     ` Jason Gunthorpe
     [not found]       ` <20180904151638.GL335-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
2018-09-04 15:47         ` Logan Gunthorpe
2018-09-05 19:22           ` Christoph Hellwig
2018-08-30 18:53   ` [PATCH v5 13/13] nvmet: Optionally use PCI P2P memory Logan Gunthorpe
     [not found]     ` <20180830185352.3369-14-logang-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
2018-08-31  0:25       ` Sagi Grimberg
     [not found]         ` <ecbb669a-2e84-1333-7e0d-1560cf014750-NQWnxTmZq1alnMjI0IkVqw@public.gmane.org>
2018-08-31 15:41           ` Logan Gunthorpe
2018-08-30 19:20   ` [PATCH v5 00/13] Copy Offload in NVMe Fabrics with P2P PCI Memory Jerome Glisse
     [not found]     ` <20180830192012.GG3529-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2018-08-30 19:30       ` Logan Gunthorpe
2018-08-30 18:53 ` [PATCH v5 03/13] PCI/P2PDMA: Add PCI p2pmem DMA mappings to adjust the bus offset Logan Gunthorpe
2018-08-30 18:53 ` [PATCH v5 11/13] nvme-pci: Add a quirk for a pseudo CMB Logan Gunthorpe
2018-08-30 18:53 ` [PATCH v5 12/13] nvmet: Introduce helper functions to allocate and free request SGLs Logan Gunthorpe
     [not found]   ` <20180830185352.3369-13-logang-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org>
2018-08-31  0:14     ` Sagi Grimberg

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20180831171906.00002751@huawei.com \
    --to=jonathan.cameron-hv44wf8li93qt0dzr+alfa@public.gmane.org \
    --cc=alex.williamson-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org \
    --cc=benh-XVmvHMARGAS8U2dJNN8I7kB+6BGkLq7r@public.gmane.org \
    --cc=bhelgaas-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org \
    --cc=christian.koenig-5C7GfCeVMHo@public.gmane.org \
    --cc=hch-jcswGhMUV9g@public.gmane.org \
    --cc=jgg-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org \
    --cc=jglisse-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org \
    --cc=linux-block-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=linux-nvdimm-hn68Rpc1hR1g9hUCZPvPmw@public.gmane.org \
    --cc=linux-nvme-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org \
    --cc=linux-pci-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=logang-OTvnGxWRz7hWk0Htik3J/w@public.gmane.org \
    --cc=maxg-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).