Received: by 2002:ac0:aed5:0:0:0:0:0 with SMTP id t21csp1597497imb; Sat, 2 Mar 2019 23:28:01 -0800 (PST) X-Google-Smtp-Source: AHgI3IZM58TN4Oo9QIcKVPjdsdWaex9CLY/yvxwh6P6kEMIY93JExGEWwZ3AI3PNBbTWeBamS3EK X-Received: by 2002:a62:6f06:: with SMTP id k6mr13922405pfc.257.1551598081532; Sat, 02 Mar 2019 23:28:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551598081; cv=none; d=google.com; s=arc-20160816; b=CkWylnlVgpIyqq279YvRLW0rmSJbHyZV2SfAuKY62lJPmGV+v1yd7HBIfKn0GMOpMS UW44STI4QoOWKLoQGaVxWFUcrIlmcXOetJnjlS2s1sp4ej9zfOPfIcADRhLl55TIIuSg wsmKOZqvY04JTTvcX9pClsniIMGGI52P0GqKIRkgJVu72Wx8m3hYrD0gRNwOv+NwGZRD JDTPqpWe/cfnCGseKqX4MX1nWPStIQqhIOAzc40sn18Hpb6JoWfIs2TjQZ52PjI67RS0 E4sa7fN+fnjO5XfbnHEQeO13EHcT9kzsd5H0xu7puyzytIJyO9IFP+Cb95bb2MLVNhy4 ckMA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:thread-index:thread-topic :content-transfer-encoding:mime-version:subject:references :in-reply-to:message-id:cc:to:from:date; bh=QsgjurIyHtrP3K3KuyVQ/FFSWkkG6qz+RIl54GbU7Bw=; b=RDffB46x/4UbjfAIM+XV4wIvWIFpfDWbAs+MHNMo/w+99NMGQjEyYuI0xhe76Y+XXL USqo3IprEbH/c07I0+ZJ4jyMzSLPB5jLbn7PuRjCHqUxZfHtQhsna07WX6U9OJasFwNa iaahJ0fkazx2dfY8OaORUDR4VD6IkOMQphirMb3T7pfu7wp4KHJvv7QHQ103AhAsYdQ+ sW+VdXxp0oJTAihjRlt7mU98PsozGsy2hjEhRb3LYbKCz2GcJgRvqUCqu+TAgMqr0nKP AjRJIsE0YckoALxHEddZ6oNJgcCJj7gvDFzDsaoLBGF6Ysua2Nu4XBDzfNawTsc/1SRY 4uaA== 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 x14si2393746pgh.98.2019.03.02.23.27.34; Sat, 02 Mar 2019 23:28:01 -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 S1725983AbfCCH1E (ORCPT + 99 others); Sun, 3 Mar 2019 02:27:04 -0500 Received: from mx1.redhat.com ([209.132.183.28]:41796 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725877AbfCCH1E (ORCPT ); Sun, 3 Mar 2019 02:27:04 -0500 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.phx2.redhat.com [10.5.11.14]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id C815981F0E; Sun, 3 Mar 2019 07:27:03 +0000 (UTC) Received: from colo-mx.corp.redhat.com (colo-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.20]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 7513B5D9CA; Sun, 3 Mar 2019 07:27:03 +0000 (UTC) Received: from zmail17.collab.prod.int.phx2.redhat.com (zmail17.collab.prod.int.phx2.redhat.com [10.5.83.19]) by colo-mx.corp.redhat.com (Postfix) with ESMTP id BAAAB1819AFE; Sun, 3 Mar 2019 07:27:02 +0000 (UTC) Date: Sun, 3 Mar 2019 02:27:02 -0500 (EST) From: Jan Stancek To: Andrea Arcangeli , peterz@infradead.org Cc: linux-mm@kvack.org, akpm@linux-foundation.org, willy@infradead.org, riel@surriel.com, mhocko@suse.com, ying huang , jrdr linux , jglisse@redhat.com, aneesh kumar , david@redhat.com, raquini@redhat.com, rientjes@google.com, kirill@shutemov.name, mgorman@techsingularity.net, linux-kernel@vger.kernel.org Message-ID: <701776300.4537344.1551598022408.JavaMail.zimbra@redhat.com> In-Reply-To: <20190302185144.GD31083@redhat.com> References: <20190302171043.GP11592@bombadil.infradead.org> <20190302185144.GD31083@redhat.com> Subject: Re: [PATCH v2] mm/memory.c: do_fault: avoid usage of stale vm_area_struct MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit X-Originating-IP: [10.40.204.28, 10.4.195.18] Thread-Topic: mm/memory.c: do_fault: avoid usage of stale vm_area_struct Thread-Index: pAmRXCN5CetzZ5PIfXitNyEm+tfURQ== X-Scanned-By: MIMEDefang 2.79 on 10.5.11.14 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.27]); Sun, 03 Mar 2019 07:27:04 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org ----- Original Message ----- > Hello Jan, > > On Sat, Mar 02, 2019 at 07:19:39PM +0100, Jan Stancek wrote: > > + struct mm_struct *vm_mm = READ_ONCE(vma->vm_mm); > > The vma->vm_mm cannot change under gcc there, so no need of > READ_ONCE. The release of mmap_sem has release semantics so the > vma->vm_mm access cannot be reordered after up_read(mmap_sem) either. > > Other than the above detail: > > Reviewed-by: Andrea Arcangeli Thank you for review, I dropped READ_ONCE and sent v3 with your Reviewed-by included. I also successfully re-ran tests over-night. > Would this not need a corresponding WRITE_ONCE() in vma_init() ? There's at least 2 context switches between, so I think it wouldn't matter. My concern was gcc optimizing out vm_mm, and vma->vm_mm access happening only after do_read_fault().