From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id BB97EC433EF for ; Tue, 5 Oct 2021 16:34:12 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 4570C61409 for ; Tue, 5 Oct 2021 16:34:12 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.4.1 mail.kernel.org 4570C61409 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=gmail.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=kvack.org Received: by kanga.kvack.org (Postfix) id 90F41900002; Tue, 5 Oct 2021 12:34:11 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 8BE996B0074; Tue, 5 Oct 2021 12:34:11 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 7ACEF900002; Tue, 5 Oct 2021 12:34:11 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0173.hostedemail.com [216.40.44.173]) by kanga.kvack.org (Postfix) with ESMTP id 6C3A16B0073 for ; Tue, 5 Oct 2021 12:34:11 -0400 (EDT) Received: from smtpin01.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay01.hostedemail.com (Postfix) with ESMTP id 216E618147E4E for ; Tue, 5 Oct 2021 16:34:11 +0000 (UTC) X-FDA: 78662931102.01.743BCEC Received: from mail-pj1-f41.google.com (mail-pj1-f41.google.com [209.85.216.41]) by imf24.hostedemail.com (Postfix) with ESMTP id CB9D6B0013A6 for ; Tue, 5 Oct 2021 16:34:10 +0000 (UTC) Received: by mail-pj1-f41.google.com with SMTP id oa12-20020a17090b1bcc00b0019f715462a8so13897pjb.3 for ; Tue, 05 Oct 2021 09:34:10 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=mime-version:subject:from:in-reply-to:date:cc :content-transfer-encoding:message-id:references:to; bh=X4UAiILtlqpir+FKeoRNV4x1N5OoKpbqJcIeFt+W4z0=; b=nPm8hTbqUolq9owT0eCIHb76kdbcP5YHuG5BQyo8HY1K6RvkqbAfWq6nmqyZo7GiUd GAguWZYspMeuvCoUKLVNNxDPn5CzvNhycCDWqc6m9RSgYkm75l7rKMnEpimHFyChAf05 GzHnpYiU0clKjLrVya+Z6AyBJWgO+lu3SuONZSDzLv9wa40I1JIV9ICKxTkgfCOo5PWG vnFLa+SI7PBWwaTS2go3m0HuStM1lAZ5dFgLPh/aE/zPayfZTTKqPPd3GvrvRFkHjTnA e6B96CMfaMdVR4jMMoLtDgQRB2KtM6mY8l1ffCi/rq9jbdZxJxKcLxkMekF8yOOAiTS3 YQ7A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:subject:from:in-reply-to:date:cc :content-transfer-encoding:message-id:references:to; bh=X4UAiILtlqpir+FKeoRNV4x1N5OoKpbqJcIeFt+W4z0=; b=IxFqfxMRNUHdRQCRZAwvbBj+D3LApXredJGkKqEb+SIgkvt32imlSVDMwDIwQUivMd 8QwJN2FqiqQExZEOLbFGbRbl42EcIGt1g8SBjrwDUtMAW/b7kiMmJy/u7aT++1RmvcMx sxrpfC1aRQ+p8zKOfoYk2TqaAj4on7Uppebi8afj0HWCFlyoIz5BJkCqGHzeiZAsfjO+ LilqdBRjyTlNgwfqGhaf/0k1ZGatm3qLxNtGofofH3jVJC88eRK86ybWYqsB9/P8IdfM QeQBHiKLt8E2aWJZaQgxaOktNot0BL+kqWG/2k/24xBVna5Qg0D4bJPbsu0cV3U06vpV XLHQ== X-Gm-Message-State: AOAM533xrFohbtB+xk9Z/xuS1wakUX557UDo4XogFluaiElqb9Dtu/3z G2JCSqswYNhqRCK3pBGV6l8= X-Google-Smtp-Source: ABdhPJy3Ix8ec/7oD0cABogXjyNkqGO7ZAx56JZRzbtMtRkrerIhsPASRZW9d87zn7PVLJmJr99uJQ== X-Received: by 2002:a17:90a:ee87:: with SMTP id i7mr4911672pjz.139.1633451649582; Tue, 05 Oct 2021 09:34:09 -0700 (PDT) Received: from smtpclient.apple (c-24-6-216-183.hsd1.ca.comcast.net. [24.6.216.183]) by smtp.gmail.com with ESMTPSA id 23sm17615107pgk.89.2021.10.05.09.34.07 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Tue, 05 Oct 2021 09:34:08 -0700 (PDT) Content-Type: text/plain; charset=utf-8 Mime-Version: 1.0 (Mac OS X Mail 14.0 \(3654.120.0.1.13\)) Subject: Re: [PATCH 1/2] mm/mprotect: use mmu_gather From: Nadav Amit In-Reply-To: <20211005065335.GG4323@worktop.programming.kicks-ass.net> Date: Tue, 5 Oct 2021 09:34:06 -0700 Cc: Andrew Morton , LKML , Linux-MM , Peter Xu , Andrea Arcangeli , Andrew Cooper , Andy Lutomirski , Dave Hansen , Thomas Gleixner , Will Deacon , Yu Zhao , Nick Piggin , x86@kernel.org Content-Transfer-Encoding: quoted-printable Message-Id: <00EDCFA2-5BFE-4C7A-A41A-DD8902F0E494@gmail.com> References: <20210925205423.168858-1-namit@vmware.com> <20210925205423.168858-2-namit@vmware.com> <20211003121019.GF4323@worktop.programming.kicks-ass.net> <620B1A38-1457-4F77-8666-E73A318392B6@gmail.com> <20211005065335.GG4323@worktop.programming.kicks-ass.net> To: Peter Zijlstra X-Mailer: Apple Mail (2.3654.120.0.1.13) Authentication-Results: imf24.hostedemail.com; dkim=pass header.d=gmail.com header.s=20210112 header.b=nPm8hTbq; spf=pass (imf24.hostedemail.com: domain of nadav.amit@gmail.com designates 209.85.216.41 as permitted sender) smtp.mailfrom=nadav.amit@gmail.com; dmarc=pass (policy=none) header.from=gmail.com X-Rspamd-Server: rspam04 X-Rspamd-Queue-Id: CB9D6B0013A6 X-Stat-Signature: h695y8ucta19xqqzo4k66agw187yy4c4 X-HE-Tag: 1633451650-96418 X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: > On Oct 4, 2021, at 11:53 PM, Peter Zijlstra = wrote: >=20 > On Mon, Oct 04, 2021 at 12:24:14PM -0700, Nadav Amit wrote: >>=20 >>=20 >>> On Oct 3, 2021, at 5:10 AM, Peter Zijlstra = wrote: >>>=20 >>> On Sat, Sep 25, 2021 at 01:54:22PM -0700, Nadav Amit wrote: >>>=20 >>>> @@ -338,25 +344,25 @@ static unsigned long = change_protection_range(struct vm_area_struct *vma, >>>> struct mm_struct *mm =3D vma->vm_mm; >>>> pgd_t *pgd; >>>> unsigned long next; >>>> - unsigned long start =3D addr; >>>> unsigned long pages =3D 0; >>>> + struct mmu_gather tlb; >>>>=20 >>>> BUG_ON(addr >=3D end); >>>> pgd =3D pgd_offset(mm, addr); >>>> flush_cache_range(vma, addr, end); >>>> inc_tlb_flush_pending(mm); >>>=20 >>> That seems unbalanced... >>=20 >> Bad rebase. Thanks for catching it! >>=20 >>>=20 >>>> + tlb_gather_mmu(&tlb, mm); >>>> + tlb_start_vma(&tlb, vma); >>>> do { >>>> next =3D pgd_addr_end(addr, end); >>>> if (pgd_none_or_clear_bad(pgd)) >>>> continue; >>>> - pages +=3D change_p4d_range(vma, pgd, addr, next, = newprot, >>>> + pages +=3D change_p4d_range(&tlb, vma, pgd, addr, next, = newprot, >>>> cp_flags); >>>> } while (pgd++, addr =3D next, addr !=3D end); >>>>=20 >>>> - /* Only flush the TLB if we actually modified any entries: */ >>>> - if (pages) >>>> - flush_tlb_range(vma, start, end); >>>> - dec_tlb_flush_pending(mm); >>>=20 >>> ... seeing you do remove the extra decrement. >>=20 >> Is it really needed? We do not put this comment elsewhere for >> tlb_finish_mmu(). But no problem, I=E2=80=99ll keep it. >=20 > -ENOPARSE, did you read decrement as comment? In any case, I don't > particularly care about the comment, and tlb_*_mmu() imply the inc/dec > thingies. >=20 > All I tried to do is point out that removing the dec but leaving the = inc > is somewhat inconsistent :-) The autocorrect in my mind was broken so I read as =E2=80=9Cdocumentation=E2= =80=9D instead of =E2=80=9Cdecrement=E2=80=9D. I will send v2 soon. Thanks again! Nadav=20=