Received: by 2002:a05:6358:e9c4:b0:b2:91dc:71ab with SMTP id hc4csp1020855rwb; Thu, 4 Aug 2022 15:46:42 -0700 (PDT) X-Google-Smtp-Source: AA6agR49/eorLiHbVv2HUpNZx7ID7lpzRoBQmq89Q4CHbeyacuEyC+t2f/evfrF1jrsutz3U14Mv X-Received: by 2002:a17:906:9b15:b0:730:d10f:a932 with SMTP id eo21-20020a1709069b1500b00730d10fa932mr3039259ejc.304.1659653202472; Thu, 04 Aug 2022 15:46:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1659653202; cv=none; d=google.com; s=arc-20160816; b=ptVKI0Jp1b+ew5QOTSg6se3DnFnE/j01xCWt99PRAXWAjeaYrc10DhYrCn1O4Tcr6q kio8BVpJ4G4PFirmNki6WdjRUC/zBgLhsBGN6Wj98ZE6ejCGou+AsvdkmbDRXb0kgasO 5kgatuOlJJF+CDRxNeFjUb799EAtg75OtVuqDTljhIlbDJYrIdn7Q3h91C1eZwcf6jXn yWsMwG1RQZdmeBpRTsEfeqZj8ph6H+y6KMdrIvL8UzZm7zdy8VXfh7mYC+bsdrbkxdE7 qzZ/GkWMdCg2jKbF/3ss/Xb1BnZndCoMG0xGfAZePyYOjwriSk1hwdkGfxKQItXx4Bqc 1YrA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date :dkim-signature; bh=KK/yBjyZqQ2OihDmxB0NVwN0meZrblS0B/JH4EeE9pg=; b=a2GYyK6cbCGCOf1FhZvCbFG8K/DJPzMXve1/LkpfkZrvxCtQhOVgwWiEsgiAqYJftx 1OVZmNr9jywejlWarJvY7jp8R0kL+SrdyacTYlYHtbdgetSxZIY8YRkUDj2rJNA/jBfW ID7jGwKz7dSvNhX1TtKMqO6e1GmSjHBMCUE2qV3FOIY3WbXJfMgM7cjW2Uwz8Ikk+SYy iN9aDDU6HhcMVdnnzCdo6dgmgdZdUqPmSBYV1Yr32mF0wVzBngi8FzKJR/WTOY+QJS7+ 847A6nrXtQc7GLUQwLGrqn1LyMW/WKTm2ceHjMjqqENDCOd9fAw498lTnBq6CAuDRjBB FzTw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux-foundation.org header.s=korg header.b=OX3gFSgc; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id dd8-20020a1709069b8800b0072ce2e430efsi1891886ejc.227.2022.08.04.15.46.17; Thu, 04 Aug 2022 15:46:42 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linux-foundation.org header.s=korg header.b=OX3gFSgc; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235406AbiHDWky (ORCPT + 99 others); Thu, 4 Aug 2022 18:40:54 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34412 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232163AbiHDWkx (ORCPT ); Thu, 4 Aug 2022 18:40:53 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8B433248EE for ; Thu, 4 Aug 2022 15:40:52 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id CF4C861862 for ; Thu, 4 Aug 2022 22:40:51 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id EE68EC433D7; Thu, 4 Aug 2022 22:40:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linux-foundation.org; s=korg; t=1659652851; bh=HC3VLcyNerHzBCf5Q7tnpfnSFobvXPDPWfF49Lx8cz0=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=OX3gFSgcbaDGFfMXilhc5jn1RKyrYRvXBk9fvrjbTsBnN5Mb7B1RpKicgbcf12l9y j29F6tp81PnKPHHJUjRwbpccWE/+3LYgjjIKDEZfMEwKrFwCHYwsohyzClVCFS6OZg HifyYlqyvM3ckjWoalvRjxmXyaddw6S9wtbDydOQ= Date: Thu, 4 Aug 2022 15:40:50 -0700 From: Andrew Morton To: Peter Xu Cc: linux-kernel@vger.kernel.org, linux-mm@kvack.org, Yang Shi , Nadav Amit , David Hildenbrand , Konstantin Khlebnikov Subject: Re: [PATCH] mm/smaps: Don't access young/dirty bit if pte unpresent Message-Id: <20220804154050.e6ab9f8c38e2445acc5b57b1@linux-foundation.org> In-Reply-To: <20220803220329.46299-1-peterx@redhat.com> References: <20220803220329.46299-1-peterx@redhat.com> X-Mailer: Sylpheed 3.7.0 (GTK+ 2.24.33; x86_64-redhat-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 3 Aug 2022 18:03:29 -0400 Peter Xu wrote: > These bits should only be valid when the ptes are present. Introducing two > booleans for it and set it to false when !pte_present(). Please (always) describe the user visible runtime effects of the bug which is being fixed? > --- a/fs/proc/task_mmu.c > +++ b/fs/proc/task_mmu.c > @@ -527,10 +527,12 @@ static void smaps_pte_entry(pte_t *pte, unsigned long addr, > struct vm_area_struct *vma = walk->vma; > bool locked = !!(vma->vm_flags & VM_LOCKED); > struct page *page = NULL; > - bool migration = false; > + bool migration = false, young = false, dirty = false; > > if (pte_present(*pte)) { > page = vm_normal_page(vma, addr, *pte); > + young = pte_young(*pte); > + dirty = pte_dirty(*pte); > } else if (is_swap_pte(*pte)) { > swp_entry_t swpent = pte_to_swp_entry(*pte); > > @@ -560,8 +562,7 @@ static void smaps_pte_entry(pte_t *pte, unsigned long addr, > if (!page) > return; > > - smaps_account(mss, page, false, pte_young(*pte), pte_dirty(*pte), > - locked, migration); > + smaps_account(mss, page, false, young, dirty, locked, migration); > } > > #ifdef CONFIG_TRANSPARENT_HUGEPAGE > -- > 2.32.0