Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp1321306ybl; Wed, 29 Jan 2020 20:21:27 -0800 (PST) X-Google-Smtp-Source: APXvYqxFvqN2iaqFIbSeRud6EahzR4l5XoHuLPVAj+msoPQlt+GiYp2cVZySInpE8tymjvNUorzJ X-Received: by 2002:a9d:7ad9:: with SMTP id m25mr2016296otn.13.1580358087259; Wed, 29 Jan 2020 20:21:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580358087; cv=none; d=google.com; s=arc-20160816; b=r18I+2AH7b2LkhyWW0CI/Sr1ni39Nk58dmrDH1wJY7/DvKkUk1M8LLZ+AWKfXgQzHA +uOABlYNBbVF5SJsx2II+u4CnKC18bszzJBv4By60VFwHzbMahZEEI/b070wnFAcWDjh AwIbDRbj3xYS+FFGG6D9Vf4Zdu1a3IxXhVIFyjqaII0HqtLeBngo91Wg59St/pxcfQzR JccIEzVvAUc6UNiBNt0YOnn3Ad4d7jfKlzLP9ajgrY/cMI4LQACki0qT8knSKfiMsege fJHKEXx2Xu/fdf2Se9nLN3msPp4ZjnG6mPNn2n/ceX2IGxB/I+aRWH0DKaBwtOBjgdGs 9cAA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=JcdAYnVQLCb8oRIYH7JBoQDKxVGZLa/gBb3aPfXmOGY=; b=Qe9zQ3Ebhs0b21/AamPIa7ZmsgGhh/CuZIuOYfU/kUZmhA0WraN1zqpTiM76iakZvg dRuo6RPKtPX+NFDgQejpsIN+K5497U4KCtz7CaHiDPwyGx6hp4j6owI9y3bhO+jmPczA 4M0OyqkvQvTU2z8KCQLCrgt+bO2yWw3cWTX9Mgut9IpUyN/vUFJeWSMo5UfQ68RTer7M iwXL3lhM2lPCS5vjXws9/qJF4vDaWdIJtJRm+3PHuHkdv/d2nSAHvwh13z5OCTD9s2os U3W45el43pxByzncJCgxRmFRODFvxS8Y2qXAHHbx6pPdUP94jrH+/sUuRW/X4KTXh5Bf eUJg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=gIVBU7Bf; 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 w26si2220264otl.213.2020.01.29.20.21.15; Wed, 29 Jan 2020 20:21:27 -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; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=gIVBU7Bf; 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 S1727278AbgA3EUU (ORCPT + 99 others); Wed, 29 Jan 2020 23:20:20 -0500 Received: from bombadil.infradead.org ([198.137.202.133]:35276 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726871AbgA3EUU (ORCPT ); Wed, 29 Jan 2020 23:20:20 -0500 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=In-Reply-To:Content-Type:MIME-Version :References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=JcdAYnVQLCb8oRIYH7JBoQDKxVGZLa/gBb3aPfXmOGY=; b=gIVBU7BfX+LKPHHjnSQP2L7xh xjrpq80QPZ4DPbhgYrO5KqDdaZkkJfN/V7HPDRUATYJtgYJnGholvI9i9i7oMbmWf9tMLIe2reWvc qeWXf2Sloh+l9bNS1nKEkDOf3w6mkZMl9bsPE9kXBoSg8CE9+BPAIlwYVdDWASRfI6BHEJA6jV881 gDVqMr8gyaNT71X0lqPJVrXUkl9n9RThht/y2xxPTwQ2uO+L8apw4Ur5qatocUZjrmUNJ4M/xN4aQ L3LJxfrGUyVbOf8GFJhNAWQNa4ZgNWPUEzhJ0RbotBQH1hqrdYmvvTICgXRJjT67T+6wzIkpvhSzA os25Ch9Qw==; Received: from willy by bombadil.infradead.org with local (Exim 4.92.3 #3 (Red Hat Linux)) id 1ix1JL-0004TE-Fp; Thu, 30 Jan 2020 04:20:11 +0000 Date: Wed, 29 Jan 2020 20:20:11 -0800 From: Matthew Wilcox To: Qian Cai Cc: akpm@linux-foundation.org, dennis@kernel.org, tj@kernel.org, cl@linux.com, elver@google.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] mm/util: fix a data race in __vm_enough_memory() Message-ID: <20200130042011.GI6615@bombadil.infradead.org> References: <20200130025133.5232-1-cai@lca.pw> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200130025133.5232-1-cai@lca.pw> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Jan 29, 2020 at 09:51:33PM -0500, Qian Cai wrote: > "vm_committed_as.count" could be accessed concurrently as reported by > KCSAN, > > read to 0xffffffff923164f8 of 8 bytes by task 1268 on cpu 38: > __vm_enough_memory+0x43/0x280 mm/util.c:801 > mmap_region+0x1b2/0xb90 mm/mmap.c:1726 > do_mmap+0x45c/0x700 > vm_mmap_pgoff+0xc0/0x130 > vm_mmap+0x71/0x90 > elf_map+0xa1/0x1b0 > load_elf_binary+0x9de/0x2180 > search_binary_handler+0xd8/0x2b0 > __do_execve_file+0xb61/0x1080 > __x64_sys_execve+0x5f/0x70 > do_syscall_64+0x91/0xb47 > entry_SYSCALL_64_after_hwframe+0x49/0xbe > > write to 0xffffffff923164f8 of 8 bytes by task 1265 on cpu 41: > percpu_counter_add_batch+0x83/0xd0 lib/percpu_counter.c:91 > exit_mmap+0x178/0x220 include/linux/mman.h:68 > mmput+0x10e/0x270 > flush_old_exec+0x572/0xfe0 > load_elf_binary+0x467/0x2180 > search_binary_handler+0xd8/0x2b0 > __do_execve_file+0xb61/0x1080 > __x64_sys_execve+0x5f/0x70 > do_syscall_64+0x91/0xb47 > entry_SYSCALL_64_after_hwframe+0x49/0xbe > > Since only the read is operating as lockless, fix it by using > READ_ONLY() for it to avoid any possible false warning due to load You mean READ_ONCE ... > { > long allowed; > > - VM_WARN_ONCE(percpu_counter_read(&vm_committed_as) < > + VM_WARN_ONCE(READ_ONCE(vm_committed_as.count) < > -(s64)vm_committed_as_batch * num_online_cpus(), I'm really not a fan of exposing the internals of a percpu_counter outside the percpu_counter.h file. Why shouldn't this be fixed by putting the READ_ONCE() inside percpu_counter_read()?