]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
nvme-pci: use appropriate initial chunk size for HMB allocation
authorAkinobu Mita <akinobu.mita@gmail.com>
Wed, 6 Sep 2017 10:15:31 +0000 (12:15 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 5 Oct 2017 07:47:24 +0000 (09:47 +0200)
commit 30f92d62e5b41a94de2d0bbd677a6ea2fcfed74f upstream.

The initial chunk size for host memory buffer allocation is currently
PAGE_SIZE << MAX_ORDER.  MAX_ORDER order allocation is usually failed
without CONFIG_DMA_CMA.  So the HMB allocation is retried with chunk size
PAGE_SIZE << (MAX_ORDER - 1) in general, but there is no problem if the
retry allocation works correctly.

Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com>
[hch: rebased]
Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Keith Busch <keith.busch@intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/nvme/host/pci.c

index 399684685e774fb630facf0891c6e97aa05f1875..48216d349ee0f07f1fd1ecf2e8db75758a3c7055 100644 (file)
@@ -1677,7 +1677,7 @@ static int nvme_alloc_host_mem(struct nvme_dev *dev, u64 min, u64 preferred)
        u32 chunk_size;
 
        /* start big and work our way down */
-       for (chunk_size = min_t(u64, preferred, PAGE_SIZE << MAX_ORDER);
+       for (chunk_size = min_t(u64, preferred, PAGE_SIZE * MAX_ORDER_NR_PAGES);
             chunk_size >= PAGE_SIZE * 2;
             chunk_size /= 2) {
                if (!__nvme_alloc_host_mem(dev, preferred, chunk_size)) {