Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp3478imm; Thu, 20 Sep 2018 13:04:45 -0700 (PDT) X-Google-Smtp-Source: ANB0VdYP9Yw5xTyrziQc70u4cwn27LDl85zLI7Ja/OTsDQ7xOi94qVUwMbVqWty52kBgRVw0HhrK X-Received: by 2002:a62:8ad1:: with SMTP id o78-v6mr42520026pfk.17.1537473885785; Thu, 20 Sep 2018 13:04:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1537473885; cv=none; d=google.com; s=arc-20160816; b=sllLIe5aqC2KS+SMyBSrjiRsCf1IYt0NdSs1Yga3edAeM7jqLH1dc4narSFbUtwJrD bpzM7Vebc3j9z8EfYV5fnR7cPc2looqQw1WQyKqy08Cjsw3hjpprSGY6uCCY4VaxIf2M bQvjSVZ+0taizeE0IpTv+IWKIAss24YbY9Bn3p/8gW9iBV7sSR+rBuvZuwacQONxO3NW GyW4PNnzT0dMfXhz6xwljqsh5j55OYrsM1KteKADhT92oHwy/IpYN3Cod29ovoZc0ziO s+I7kuVCbNuZo3GxUhKvo83w+dZ5P0vD7SkOIFQoSI7US7/pTgHWT1bAYXcjKcMqgnjY Fj7Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=o7vU+hlMyX+n8lb/3t0kmF//HevF+bTqc6kRpEnkgJk=; b=AlD6X4MoDy0DfZ45ggTjgFYuA1KPoNA8HpYK0gkpej0P1ZOAPEu3nuMPWBvzSl6gM6 nE8nBGbZXRS3GnT678txOjq/iyOEXJGBDyA8HgSTc5Gt+uKzo5q/38sVxdn7wZb/DlGs 7etcit6n466qdjU1VUXDt0xV9UrI6HjyEiHgs9Qpa0GrS12LCqNiTkbhvs4GZkQ2CFZF 7t4+9A+S2UdQRquDxqC7RblpMZqlTio0t74SYxJafrOGJZRj2tbM5vKVQnOcYbh9dbiI 2xrabzbC2e+6jWBEiK6bGhuekdjB5xSJusY6btzmbNB2gyWu1tCpRbj4GtORtYwyDcL4 7DRQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id u10-v6si23880801plr.58.2018.09.20.13.04.29; Thu, 20 Sep 2018 13:04:45 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388503AbeIUBsh (ORCPT + 99 others); Thu, 20 Sep 2018 21:48:37 -0400 Received: from mga17.intel.com ([192.55.52.151]:62935 "EHLO mga17.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388299AbeIUBsD (ORCPT ); Thu, 20 Sep 2018 21:48:03 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga005.fm.intel.com ([10.253.24.32]) by fmsmga107.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 20 Sep 2018 13:02:53 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.54,281,1534834800"; d="scan'208";a="264386361" Received: from unknown (HELO localhost.lm.intel.com) ([10.232.112.44]) by fmsmga005.fm.intel.com with ESMTP; 20 Sep 2018 13:02:04 -0700 From: Keith Busch To: linux-kernel@vger.kernel.org Cc: Kirill Shutemov , Dave Hansen , Dan Williams , Keith Busch Subject: [PATCHv2 4/7] tools/gup_benchmark: Allow user specified file Date: Thu, 20 Sep 2018 14:03:55 -0600 Message-Id: <20180920200358.31680-5-keith.busch@intel.com> X-Mailer: git-send-email 2.13.6 In-Reply-To: <20180920200358.31680-1-keith.busch@intel.com> References: <20180920200358.31680-1-keith.busch@intel.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The gup benchmark by default maps anonymous memory. This patch allows a user to specify a file to map, providing a means to test various file backings, like device and filesystem DAX. Cc: Kirill Shutemov Cc: Dave Hansen Cc: Dan Williams Signed-off-by: Keith Busch --- tools/testing/selftests/vm/gup_benchmark.c | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/tools/testing/selftests/vm/gup_benchmark.c b/tools/testing/selftests/vm/gup_benchmark.c index b2082df8beb4..f2c99e2436f8 100644 --- a/tools/testing/selftests/vm/gup_benchmark.c +++ b/tools/testing/selftests/vm/gup_benchmark.c @@ -33,9 +33,12 @@ int main(int argc, char **argv) unsigned long size = 128 * MB; int i, fd, opt, nr_pages = 1, thp = -1, repeats = 1, write = 0; int cmd = GUP_FAST_BENCHMARK; + int file_map = -1; + int flags = MAP_ANONYMOUS | MAP_PRIVATE; + char *file = NULL; char *p; - while ((opt = getopt(argc, argv, "m:r:n:tTLU")) != -1) { + while ((opt = getopt(argc, argv, "m:r:n:f:tTLU")) != -1) { switch (opt) { case 'm': size = atoi(optarg) * MB; @@ -61,11 +64,22 @@ int main(int argc, char **argv) case 'w': write = 1; break; + case 'f': + file = optarg; + flags &= ~(MAP_PRIVATE | MAP_ANONYMOUS); + flags |= MAP_SHARED; + break; default: return -1; } } + if (file) { + file_map = open(file, O_RDWR|O_CREAT); + if (file_map < 0) + perror("open"), exit(file_map); + } + gup.nr_pages_per_call = nr_pages; gup.flags = write; @@ -73,8 +87,7 @@ int main(int argc, char **argv) if (fd == -1) perror("open"), exit(1); - p = mmap(NULL, size, PROT_READ | PROT_WRITE, - MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); + p = mmap(NULL, size, PROT_READ | PROT_WRITE, flags, file_map, 0); if (p == MAP_FAILED) perror("mmap"), exit(1); gup.addr = (unsigned long)p; -- 2.14.4