Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp9800317ybi; Wed, 24 Jul 2019 10:09:42 -0700 (PDT) X-Google-Smtp-Source: APXvYqxAeK7IL5QGfdYp/MxfeYm8NNRHVjZ+xIu5DpXYa1N7wmuYHxkY3NJMbHJQjUdLFCya8XrT X-Received: by 2002:a62:7d13:: with SMTP id y19mr12315857pfc.62.1563988182683; Wed, 24 Jul 2019 10:09:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563988182; cv=none; d=google.com; s=arc-20160816; b=MFVEAuYIjXhtSXs4L/w4d6/I4rYtLMt+T0lisDI7cW1op8KktOvQ323qppMMfpl9Ht ta1WFPt+vRLuAWJq/pC3oICi3S5fW4bQ+Pcdg/bZ7M71m4oIl6bHGG5a0p+7hYCDrtfm HT4mk6tdwuHc+XdXXKc1jqzRPQ27ta0gtHCGsdp7D+SxTO2kYwHC0VgOqTw5H8J1j1YL 43uoliRF2Q6v9quyewVSz6ee0D14ZzLFVkJ1IpuR8klhA/wgheh3bxlpi57+jZEbg818 TekbIeMTXHF0HzzPQCndy9l6yCW77KHidoHVmwAPdE5OnJVSJ2SraMMmStRJ6fOibWQr 1QvQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=N+5GDocIaGJNeeiAfHSOPi2SmVdT4rQLPHKSD9PsZ+I=; b=g0CZ3OicOlwWw7M7x46PAmyytSPzU6DAw1gFerV1FoSEb5l+lazJ4H5RdfkJ56jmjb qTPqWl6dVT240smybLtZLsJ1PaBpWH6QdwNCrfVTL1Iu392NeT4z/b/SvHue27F9kvxb TSLJ00qPhwLFpRZdqkieSVw0Kdd/W+PkYq4jjJZZtHHHkx5MLokFzMncdyR9n+Ug/Heq YX/+2cq0tnbF0XjVUx34WRrGpSI4fPymiSfhKLcYGRaSvSl6kkAz3jGCVmttbdBsogjU sXVve3Zw3jUwt7SuK/nvQdV+D/flT/CxrPdKck1SPFX+3koreRtsyuZVhoJeAbMFOYiu 7H4Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ziepe.ca header.s=google header.b=YDxsaLxk; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x13si16540416plr.111.2019.07.24.10.09.27; Wed, 24 Jul 2019 10:09:42 -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; dkim=pass header.i=@ziepe.ca header.s=google header.b=YDxsaLxk; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727581AbfGXQxU (ORCPT + 99 others); Wed, 24 Jul 2019 12:53:20 -0400 Received: from mail-qk1-f193.google.com ([209.85.222.193]:41387 "EHLO mail-qk1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726031AbfGXQxU (ORCPT ); Wed, 24 Jul 2019 12:53:20 -0400 Received: by mail-qk1-f193.google.com with SMTP id v22so34252570qkj.8 for ; Wed, 24 Jul 2019 09:53:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ziepe.ca; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=N+5GDocIaGJNeeiAfHSOPi2SmVdT4rQLPHKSD9PsZ+I=; b=YDxsaLxkea1VSwYyvtzIkxG5oCvSkigPxhBkQShb6z3NiUMmOxfDu1eZ6zFkom7daU u8h/zoLkQOxwJRbiaCw2/8hNE/Bht5HY3TCoiCttwyptVd1mPoS+GRxRkwK0cCm3iq22 7qkf+dpbC+KGjNEaO8b5+LWigp5rJLzAXzsj2ylO1gPUf+tQ5JrgQJnV1nENWsjnyYa9 9VarDOham+q+ATGl5AwzqF39bSfue6F3vqwEURcqG21pxm9lVbVSoUgMl1phRmPztF8C CtiYbpiK44hufWFvehcheJDYUXoVOSEOaAY2meip1/99aZ9WTovpxbewVKfaicsyRLaG Ke3g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=N+5GDocIaGJNeeiAfHSOPi2SmVdT4rQLPHKSD9PsZ+I=; b=PvjAgKPRela1Jr8e8BRTPTR6bbvVksuSMAeltlE+ciUmX3qnpp34828aENzI/JF92V 1GyBl1WWnce7Tx+EAufaysrZb9EPN8AzbJnqEgbAvLYgRj3XRjWdlfLr+WIK9CDh8cgu 7yTYl0e1GjOYsdyn7o4slxtSRAOdj7Um4qD/rsMf4hke83BblIASPCKUTJGB+QkNO9/i CseL1Zjk4z4Whr4eywKt3AyYhH1q+u1sa/lrqjaXZwXHUtI3anUxxzgW8Tc5I+HialUD S9vN6baWrpThUq98Q5AgzBNvmi6HNQPnUufnXEQKcYtfybZ/rvtDZXpOXZ8n1ofT8upj adeQ== X-Gm-Message-State: APjAAAVYg3/e2GSEzLLuAUNt0T2hzqCozxqwfUG24sKdwFLbg0gabwST fj9aY8Kr5OORI3gZILstgQsKfw== X-Received: by 2002:a05:620a:232:: with SMTP id u18mr53141490qkm.131.1563987199405; Wed, 24 Jul 2019 09:53:19 -0700 (PDT) Received: from ziepe.ca (hlfxns017vw-156-34-55-100.dhcp-dynamic.fibreop.ns.bellaliant.net. [156.34.55.100]) by smtp.gmail.com with ESMTPSA id q12sm19415581qkm.126.2019.07.24.09.53.18 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Wed, 24 Jul 2019 09:53:18 -0700 (PDT) Received: from jgg by mlx.ziepe.ca with local (Exim 4.90_1) (envelope-from ) id 1hqKVx-0002lr-R9; Wed, 24 Jul 2019 13:53:17 -0300 Date: Wed, 24 Jul 2019 13:53:17 -0300 From: Jason Gunthorpe To: "Michael S. Tsirkin" Cc: Jason Wang , syzbot , aarcange@redhat.com, akpm@linux-foundation.org, christian@brauner.io, davem@davemloft.net, ebiederm@xmission.com, elena.reshetova@intel.com, guro@fb.com, hch@infradead.org, james.bottomley@hansenpartnership.com, jglisse@redhat.com, keescook@chromium.org, ldv@altlinux.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org, linux-parisc@vger.kernel.org, luto@amacapital.net, mhocko@suse.com, mingo@kernel.org, namit@vmware.com, peterz@infradead.org, syzkaller-bugs@googlegroups.com, viro@zeniv.linux.org.uk, wad@chromium.org Subject: Re: WARNING in __mmdrop Message-ID: <20190724165317.GD28493@ziepe.ca> References: <20190723010156-mutt-send-email-mst@kernel.org> <124be1a2-1c53-8e65-0f06-ee2294710822@redhat.com> <20190723032800-mutt-send-email-mst@kernel.org> <20190723062221-mutt-send-email-mst@kernel.org> <9baa4214-67fd-7ad2-cbad-aadf90bbfc20@redhat.com> <20190723110219-mutt-send-email-mst@kernel.org> <20190724040238-mutt-send-email-mst@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190724040238-mutt-send-email-mst@kernel.org> User-Agent: Mutt/1.9.4 (2018-02-28) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Jul 24, 2019 at 04:05:17AM -0400, Michael S. Tsirkin wrote: > On Wed, Jul 24, 2019 at 10:17:14AM +0800, Jason Wang wrote: > > So even PTE is read speculatively before reading invalidate_count (only in > > the case of invalidate_count is zero). The spinlock has guaranteed that we > > won't read any stale PTEs. > > I'm sorry I just do not get the argument. > If you want to order two reads you need an smp_rmb > or stronger between them executed on the same CPU. No, that is only for unlocked algorithms. In this case the spinlock provides all the 'or stronger' ordering required. For invalidate_count going 0->1 the spin_lock ensures that any following PTE update during invalidation does not order before the spin_lock() While holding the lock and observing 1 in invalidate_count the PTE values might be changing, but are ignored. C's rules about sequencing make this safe. For invalidate_count going 1->0 the spin_unlock ensures that any preceeding PTE update during invalidation does not order after the spin_unlock While holding the lock and observing 0 in invalidating_count the PTE values cannot be changing. Jason