• L
    nvme-pci: Use PCI p2pmem subsystem to manage the CMB · 0f238ff5
    Logan Gunthorpe 提交于
    Register the CMB buffer as p2pmem and use the appropriate allocation
    functions to create and destroy the IO submission queues.
    
    If the CMB supports WDS and RDS, publish it for use as P2P memory by other
    devices.
    
    Kernels without CONFIG_PCI_P2PDMA will also no longer support NVMe CMB.
    However, seeing the main use-cases for the CMB is P2P operations, this
    seems like a reasonable dependency.
    
    We drop the __iomem safety on the buffer seeing that, by convention, it's
    safe to directly access memory mapped by memremap()/devm_memremap_pages().
    Architectures where this is not safe will not be supported by memremap()
    and therefore will not support PCI P2P and have no support for CMB.
    Signed-off-by: NLogan Gunthorpe <logang@deltatee.com>
    Signed-off-by: NBjorn Helgaas <bhelgaas@google.com>
    Reviewed-by: NKeith Busch <keith.busch@intel.com>
    Reviewed-by: NChristoph Hellwig <hch@lst.de>
    0f238ff5
pci.c 69.4 KB