Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp1841894ybh; Fri, 17 Jul 2020 02:38:41 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwfyrAjc0o91BYsYymwleAEW9YAGTgb8zVMf1v475kPXvNIKc9NQ/KMzCk4hI+t2w8GwE/1 X-Received: by 2002:a17:906:d92a:: with SMTP id rn10mr5230015ejb.169.1594978721004; Fri, 17 Jul 2020 02:38:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594978720; cv=none; d=google.com; s=arc-20160816; b=wsXZjJ4VD/qowIpu/emw4hF9/Wfnp0GeH77er27hgpAsD2uIe2zFeM0nAn6+uTiuzc D+iquge0f+HNgGqWiRRuXLIZz2nYlyuMo8chAPulOv1dmojeu86vWoCcBZsyAe6Ako1E WMPPy92m0d54k5UV+ARqHcQ28rkURQCAi9dB36vYst7G3myjpQ5RSWwqzBpUNlLOzoFA 9Gl/juYcIPSqNPUXL3imBB4WIDoRFz/Of5RcekYcO/ZpWPCj0gWolqcqg7GP5zDpG5r4 KOEWhnBG3ePAqCsbIxd12tkbmrqQWipvFXTOLjVdVoHXvvluQWgRXalEZCGAdAJqS55/ QNWQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=8Q103/EAQ4CTKovfJeZNWlo5MBfpmT5iyxD/zfKEauE=; b=WkYKgAZN6psRvHJZ+UYmOh6/FLQVRSk/K89+e2Bk60vJhvuSQA1jRuzOBzUlgv7ogl 4AhFLzsGYn8YPiqfZZhXSPi2TEn8rOzpzwcorgHSZmLjO1MbRY9BOSce82XszOEYsupv BOdEtqPFvmW6Kl9ewDbzSzNiv1250/yAnWkujlHvgd3TpmijPRBLk5uQ/toIMsD0TseM uFMCJzLd0FQQFYW9uU+WpsRFhJNS6bRTAZdOw15bjywhAI6w32aWaPwmqX3OKn1WgSVv Fd2iHpC2FVS+RG1zIndbBsaUvcilZhI7tMLUXu4eNdMTwnwBG2ABJaBFD+vT82UEMK4y Rwpg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g12si4736112edn.412.2020.07.17.02.38.18; Fri, 17 Jul 2020 02:38:40 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726691AbgGQJfg (ORCPT + 99 others); Fri, 17 Jul 2020 05:35:36 -0400 Received: from out30-57.freemail.mail.aliyun.com ([115.124.30.57]:55161 "EHLO out30-57.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725932AbgGQJfg (ORCPT ); Fri, 17 Jul 2020 05:35:36 -0400 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R191e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e04426;MF=shile.zhang@linux.alibaba.com;NM=1;PH=DS;RN=6;SR=0;TI=SMTPD_---0U3-7-os_1594978521; Received: from e18g09479.et15sqa.tbsite.net(mailfrom:shile.zhang@linux.alibaba.com fp:SMTPD_---0U3-7-os_1594978521) by smtp.aliyun-inc.com(127.0.0.1); Fri, 17 Jul 2020 17:35:33 +0800 From: Shile Zhang To: "Michael S . Tsirkin" , Jason Wang Cc: virtualization@lists.linux-foundation.org, linux-kernel@vger.kernel.org, Shile Zhang , Jiang Liu Subject: [PATCH] virtio_ring: use alloc_pages_node for NUMA-aware allocation Date: Fri, 17 Jul 2020 17:35:04 +0800 Message-Id: <20200717093504.47794-1-shile.zhang@linux.alibaba.com> X-Mailer: git-send-email 2.24.0.rc2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Use alloc_pages_node() allocate memory for vring queue with proper NUMA affinity. Suggested-by: Jiang Liu Signed-off-by: Shile Zhang --- drivers/virtio/virtio_ring.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/drivers/virtio/virtio_ring.c b/drivers/virtio/virtio_ring.c index 58b96baa8d48..ded82880281a 100644 --- a/drivers/virtio/virtio_ring.c +++ b/drivers/virtio/virtio_ring.c @@ -276,9 +276,11 @@ static void *vring_alloc_queue(struct virtio_device *vdev, size_t size, return dma_alloc_coherent(vdev->dev.parent, size, dma_handle, flag); } else { - void *queue = alloc_pages_exact(PAGE_ALIGN(size), flag); - - if (queue) { + void *queue = NULL; + struct page *page = alloc_pages_node(dev_to_node(&vdev->dev.parent), + flag, get_order(size)); + if (page) { + queue = page_address(page); phys_addr_t phys_addr = virt_to_phys(queue); *dma_handle = (dma_addr_t)phys_addr; @@ -308,7 +310,7 @@ static void vring_free_queue(struct virtio_device *vdev, size_t size, if (vring_use_dma_api(vdev)) dma_free_coherent(vdev->dev.parent, size, queue, dma_handle); else - free_pages_exact(queue, PAGE_ALIGN(size)); + free_pages((unsigned long)queue, get_order(size)); } /* -- 2.24.0.rc2