Linux-NVME Archive on lore.kernel.org
 help / color / mirror / Atom feed
From: Christoph Hellwig <hch@lst.de>
To: Keith Busch <kbusch@kernel.org>
Cc: sagi@grimberg.me, linux-kernel@vger.kernel.org,
	linux-nvme@lists.infradead.org, axboe@fb.com,
	Baolin Wang <baolin.wang@linux.alibaba.com>,
	baolin.wang7@gmail.com, Christoph Hellwig <hch@lst.de>
Subject: Re: [PATCH 2/3] nvme-pci: Add controller memory buffer supported macro
Date: Wed, 24 Jun 2020 07:47:08 +0200	[thread overview]
Message-ID: <20200624054708.GA17008@lst.de> (raw)
In-Reply-To: <20200624025817.GC1291930@dhcp-10-100-145-180.wdl.wdc.com>

On Tue, Jun 23, 2020 at 07:58:17PM -0700, Keith Busch wrote:
> On Tue, Jun 23, 2020 at 06:27:51PM +0200, Christoph Hellwig wrote:
> > On Tue, Jun 23, 2020 at 09:24:33PM +0800, Baolin Wang wrote:
> > > Introduce a new capability macro to indicate if the controller
> > > supports the memory buffer or not, instead of reading the
> > > NVME_REG_CMBSZ register.
> > 
> > This is a complex issue.  The CMBS bit was only added in NVMe 1.4 as
> > a backwards incompatible change, as the CMB addressing scheme can lead
> > to data corruption.  The CMBS was added as part of the horribe hack
> > that also involves the CBA field, which we'll need to see before
> > using it to work around the addressing issue.  At the same time we
> > should also continue supporting the legacy pre-1.4 CMB with a warning
> > (and may reject it if we know we run in a VM).
> 
> Well, a CMB from an emulated controller (like qemu's) can be used within
> a VM. It's only if you direct assign a PCI function that CMB usage
> breaks.

But we have no idea if a controller is assigned or emulated.

_______________________________________________
Linux-nvme mailing list
Linux-nvme@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-nvme

  reply	other threads:[~2020-06-24  5:47 UTC|newest]

Thread overview: 13+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <cover.1592916850.git.baolin.wang@linux.alibaba.com>
     [not found] ` <bf3f47ba50f72d0b775ca4bd098f183056d964ba.1592916850.git.baolin.wang@linux.alibaba.com>
2020-06-23 14:40   ` [PATCH 1/3] nvme: Add Arbitration Burst support Keith Busch
2020-06-23 17:39     ` Sagi Grimberg
2020-06-23 18:01       ` Keith Busch
2020-06-24  1:34         ` Baolin Wang
2020-06-24  2:51           ` Keith Busch
2020-06-24  2:54             ` Baolin Wang
2020-06-24  2:57   ` Keith Busch
2020-06-24  3:06     ` Baolin Wang
     [not found] ` <eab18c7696ea0e34a6ab0371d7d17ad45d1566ce.1592916850.git.baolin.wang@linux.alibaba.com>
2020-06-23 16:27   ` [PATCH 2/3] nvme-pci: Add controller memory buffer supported macro Christoph Hellwig
2020-06-24  2:07     ` Baolin Wang
2020-06-24  2:58     ` Keith Busch
2020-06-24  5:47       ` Christoph Hellwig [this message]
     [not found] ` <a64d35465b8d91ab11f37d814ac10003da7804b8.1592916850.git.baolin.wang@linux.alibaba.com>
2020-06-23 17:39   ` [PATCH 3/3] nvme: Use USEC_PER_SEC instead of magic numbers 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=20200624054708.GA17008@lst.de \
    --to=hch@lst.de \
    --cc=axboe@fb.com \
    --cc=baolin.wang7@gmail.com \
    --cc=baolin.wang@linux.alibaba.com \
    --cc=kbusch@kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-nvme@lists.infradead.org \
    --cc=sagi@grimberg.me \
    /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