Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp4873556imu; Tue, 29 Jan 2019 08:56:32 -0800 (PST) X-Google-Smtp-Source: ALg8bN6xte/T+D6SXxUEN+z1r0CVKubwlr5BscA8e0V3UavOpiLeRMWS3ZCunNDpV9pHOV34ioAM X-Received: by 2002:a63:f717:: with SMTP id x23mr24635784pgh.317.1548780992034; Tue, 29 Jan 2019 08:56:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1548780991; cv=none; d=google.com; s=arc-20160816; b=Xqs3r/xg28dpA3BR9Q6N2bgah7t/vMMFsAErdvVzDSneWEI81u0li4xYscfMMleHRq OkWOmtqr0kltEymhe94OxP1UXYpBclfGMzS12Xh25Er0rQlbFeDallqFkdVsJP+W0yfe FdCm3qFngWp/PnW7Pj2BdAY5km+SuBy6v9ONyhTuI8SM0g+A/8WmtfTlIKMUj/xJBsFC iltInzZJTqZyaNMV6MZMYzhH2qnGbQwLD7bFR9HjAfN/f91PuU+4zxkXH91yXijNr4gS jgZbzUslglZeJ//4+YEzgkr98cWmnfM+WkAsnsnP3EMWTbnq/WJcT6boebTKheQ6iM68 tu9Q== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=n2/nkvHycDGkjXSl6PLGynhqbyvPV8LWO6aSFBVE884=; b=m21eHN/E09O6lmh8JIxs6E383IjlBq/Fdld/TKZJpLGrt8ji6GTyr3SCnCEJ7x7A6M qiOuLXhVInVex+GIHe6vOSpwIidPyHivyvCNUQU6RgB6DzgHQVLpseCjSjhoSDJ2vXuV zZ/VyOXYbe9uEY30TVkRk8M2ro0bBVscKfG4965Ix4Y3rVVknf9FDjbY0TiPe5QBOTMI 5OrKzE4ae02cM2rewBZeg9XiVRs5y9Pgy7VmS1J6feZYrbClGAFdx4uBYRD8RtP6AgSe 1dNCxf+TfNoUkxEWxChwU/SF/5se4O6DBEZwFR+ZYftgHgOo1V+G/xOkQnSLewNovvtv eWGw== 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id u4si35555419pls.34.2019.01.29.08.56.16; Tue, 29 Jan 2019 08:56:31 -0800 (PST) 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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728946AbfA2Qz0 (ORCPT + 99 others); Tue, 29 Jan 2019 11:55:26 -0500 Received: from mx1.redhat.com ([209.132.183.28]:37300 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728595AbfA2Qym (ORCPT ); Tue, 29 Jan 2019 11:54:42 -0500 Received: from smtp.corp.redhat.com (int-mx07.intmail.prod.int.phx2.redhat.com [10.5.11.22]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id EDFC43DE0E; Tue, 29 Jan 2019 16:54:41 +0000 (UTC) Received: from localhost.localdomain.com (ovpn-122-2.rdu2.redhat.com [10.10.122.2]) by smtp.corp.redhat.com (Postfix) with ESMTP id E1FCA103BAB6; Tue, 29 Jan 2019 16:54:40 +0000 (UTC) From: jglisse@redhat.com To: linux-mm@kvack.org Cc: linux-kernel@vger.kernel.org, =?UTF-8?q?J=C3=A9r=C3=B4me=20Glisse?= , Andrew Morton , Ralph Campbell , John Hubbard Subject: [PATCH 03/10] mm/hmm: improve and rename hmm_vma_get_pfns() to hmm_range_snapshot() Date: Tue, 29 Jan 2019 11:54:21 -0500 Message-Id: <20190129165428.3931-4-jglisse@redhat.com> In-Reply-To: <20190129165428.3931-1-jglisse@redhat.com> References: <20190129165428.3931-1-jglisse@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.84 on 10.5.11.22 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.29]); Tue, 29 Jan 2019 16:54:42 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jérôme Glisse Rename for consistency between code, comments and documentation. Also improves the comments on all the possible returns values. Improve the function by returning the number of populated entries in pfns array. Signed-off-by: Jérôme Glisse Cc: Andrew Morton Cc: Ralph Campbell Cc: John Hubbard --- include/linux/hmm.h | 4 ++-- mm/hmm.c | 23 ++++++++++------------- 2 files changed, 12 insertions(+), 15 deletions(-) diff --git a/include/linux/hmm.h b/include/linux/hmm.h index bd6e058597a6..ddf49c1b1f5e 100644 --- a/include/linux/hmm.h +++ b/include/linux/hmm.h @@ -365,11 +365,11 @@ void hmm_mirror_unregister(struct hmm_mirror *mirror); * table invalidation serializes on it. * * YOU MUST CALL hmm_vma_range_done() ONCE AND ONLY ONCE EACH TIME YOU CALL - * hmm_vma_get_pfns() WITHOUT ERROR ! + * hmm_range_snapshot() WITHOUT ERROR ! * * IF YOU DO NOT FOLLOW THE ABOVE RULE THE SNAPSHOT CONTENT MIGHT BE INVALID ! */ -int hmm_vma_get_pfns(struct hmm_range *range); +long hmm_range_snapshot(struct hmm_range *range); bool hmm_vma_range_done(struct hmm_range *range); diff --git a/mm/hmm.c b/mm/hmm.c index 74d69812d6be..0d9ecd3337e5 100644 --- a/mm/hmm.c +++ b/mm/hmm.c @@ -706,23 +706,19 @@ static void hmm_pfns_special(struct hmm_range *range) } /* - * hmm_vma_get_pfns() - snapshot CPU page table for a range of virtual addresses - * @range: range being snapshotted + * hmm_range_snapshot() - snapshot CPU page table for a range + * @range: range * Returns: -EINVAL if invalid argument, -ENOMEM out of memory, -EPERM invalid - * vma permission, 0 success + * permission (for instance asking for write and range is read only), + * -EAGAIN if you need to retry, -EFAULT invalid (ie either no valid + * vma or it is illegal to access that range), number of valid pages + * in range->pfns[] (from range start address). * * This snapshots the CPU page table for a range of virtual addresses. Snapshot * validity is tracked by range struct. See hmm_vma_range_done() for further * information. - * - * The range struct is initialized here. It tracks the CPU page table, but only - * if the function returns success (0), in which case the caller must then call - * hmm_vma_range_done() to stop CPU page table update tracking on this range. - * - * NOT CALLING hmm_vma_range_done() IF FUNCTION RETURNS 0 WILL LEAD TO SERIOUS - * MEMORY CORRUPTION ! YOU HAVE BEEN WARNED ! */ -int hmm_vma_get_pfns(struct hmm_range *range) +long hmm_range_snapshot(struct hmm_range *range) { struct vm_area_struct *vma = range->vma; struct hmm_vma_walk hmm_vma_walk; @@ -776,6 +772,7 @@ int hmm_vma_get_pfns(struct hmm_range *range) hmm_vma_walk.fault = false; hmm_vma_walk.range = range; mm_walk.private = &hmm_vma_walk; + hmm_vma_walk.last = range->start; mm_walk.vma = vma; mm_walk.mm = vma->vm_mm; @@ -792,9 +789,9 @@ int hmm_vma_get_pfns(struct hmm_range *range) * function return 0). */ range->hmm = hmm; - return 0; + return (hmm_vma_walk.last - range->start) >> PAGE_SHIFT; } -EXPORT_SYMBOL(hmm_vma_get_pfns); +EXPORT_SYMBOL(hmm_range_snapshot); /* * hmm_vma_range_done() - stop tracking change to CPU page table over a range -- 2.17.2