Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp1206583ybf; Thu, 27 Feb 2020 06:48:47 -0800 (PST) X-Google-Smtp-Source: APXvYqzLenULmQpgTtefGv+wejrPvs5YPFpN4BMXZ0wJFhyfsemJqmVVy2J2byVNgCwc4wTPMMii X-Received: by 2002:a9d:6ad6:: with SMTP id m22mr3843084otq.7.1582814927160; Thu, 27 Feb 2020 06:48:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582814927; cv=none; d=google.com; s=arc-20160816; b=iWSbTIHOoKjFrtzfY5oRPWnA1ORM7xOFyi4lFJvTQQCN+LJ1Ay6P9TfoXzQ5tC+uiR e/BlN0RMR/uv+hPaRVmKWVBWluJoUv2BHkec9kHpmdbhsCrCgqnHRyNUwdjzN24y2MfC V/JLVeK1ap0UuY/0tLKhbLRBDvLa4dCQ2OyKsEHpAMYRF8dNqTJzI+FDCQGlq4zB6mbY sSaMsHVEItgRSjaYKwx+N8NiRmJobo1+AuXXgejsYY9f3Q0Oz77kbI+ZZZXb+3v684GP TEEPWVQlGQMHyqrqrZIZdJLwNk+QuLxgOwrU39B54ZWYySBedir2GH95NzPT1zwAmaJu eyLQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=6LdzUCVkMHanr4XQz7velNhAeOKihIsZqYCXZy0hBGs=; b=yM6Vq+fFDA4gynXK601W98pH3+wscUiVZfcazUErZryfiqcQf0WLMH9eLAGjIjeWfS rM7oj7IehbWHqjydBnEAQTYHWxsxw/hNK77mLvDmH7Sd9lkSNH1BzZmaTZOxdZCwriTX C0DaYOFysL9VtwMuDf9i535uDsGwqbnUttMmw7+TKnnLizA0M6XXBmYGd9Rd0Kdvwy+n v3nYtHjgcA2IzVSm5FmUYJ/5Hh2l3kKQuk0webSvbK9PSlx62p3r0X/G9Ggr4Dzd9gZ1 HIriXgUxkLWxShh8JXWzb0cPPg0wt/TRTOwVEhfsgBnFmSWGWBES1yLn5/aQUqrLvf9K FCfw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=ZAr77dvl; 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 n21si1370945oic.0.2020.02.27.06.48.34; Thu, 27 Feb 2020 06:48:47 -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=pass header.i=@kernel.org header.s=default header.b=ZAr77dvl; 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 S1731934AbgB0Oqw (ORCPT + 99 others); Thu, 27 Feb 2020 09:46:52 -0500 Received: from mail.kernel.org ([198.145.29.99]:40752 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730306AbgB0NpA (ORCPT ); Thu, 27 Feb 2020 08:45:00 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 526BC20726; Thu, 27 Feb 2020 13:44:59 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1582811099; bh=t6UyTLukEOtnELE49KIh3rg/HIg9jTN0oPPumzzcZEU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ZAr77dvlpdVql2MT5Agps5brt1ISdBq65v5NjF65FSoMDYrZapEREZ9KHHK5QcTWs eIxGwxAZZuMlndgwP2w4ODvgnEhjx4cDSuS0uV6NqTOMi4QFtkCCUcu3Zn55WfvqDK w3zfn4gSMWdlfqD4jfqr8h2JveqY0jICukRNvUzQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Qian Cai , Theodore Tso , stable@kernel.org Subject: [PATCH 4.4 101/113] ext4: fix a data race in EXT4_I(inode)->i_disksize Date: Thu, 27 Feb 2020 14:36:57 +0100 Message-Id: <20200227132227.934472019@linuxfoundation.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200227132211.791484803@linuxfoundation.org> References: <20200227132211.791484803@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Qian Cai commit 35df4299a6487f323b0aca120ea3f485dfee2ae3 upstream. EXT4_I(inode)->i_disksize could be accessed concurrently as noticed by KCSAN, BUG: KCSAN: data-race in ext4_write_end [ext4] / ext4_writepages [ext4] write to 0xffff91c6713b00f8 of 8 bytes by task 49268 on cpu 127: ext4_write_end+0x4e3/0x750 [ext4] ext4_update_i_disksize at fs/ext4/ext4.h:3032 (inlined by) ext4_update_inode_size at fs/ext4/ext4.h:3046 (inlined by) ext4_write_end at fs/ext4/inode.c:1287 generic_perform_write+0x208/0x2a0 ext4_buffered_write_iter+0x11f/0x210 [ext4] ext4_file_write_iter+0xce/0x9e0 [ext4] new_sync_write+0x29c/0x3b0 __vfs_write+0x92/0xa0 vfs_write+0x103/0x260 ksys_write+0x9d/0x130 __x64_sys_write+0x4c/0x60 do_syscall_64+0x91/0xb47 entry_SYSCALL_64_after_hwframe+0x49/0xbe read to 0xffff91c6713b00f8 of 8 bytes by task 24872 on cpu 37: ext4_writepages+0x10ac/0x1d00 [ext4] mpage_map_and_submit_extent at fs/ext4/inode.c:2468 (inlined by) ext4_writepages at fs/ext4/inode.c:2772 do_writepages+0x5e/0x130 __writeback_single_inode+0xeb/0xb20 writeback_sb_inodes+0x429/0x900 __writeback_inodes_wb+0xc4/0x150 wb_writeback+0x4bd/0x870 wb_workfn+0x6b4/0x960 process_one_work+0x54c/0xbe0 worker_thread+0x80/0x650 kthread+0x1e0/0x200 ret_from_fork+0x27/0x50 Reported by Kernel Concurrency Sanitizer on: CPU: 37 PID: 24872 Comm: kworker/u261:2 Tainted: G W O L 5.5.0-next-20200204+ #5 Hardware name: HPE ProLiant DL385 Gen10/ProLiant DL385 Gen10, BIOS A40 07/10/2019 Workqueue: writeback wb_workfn (flush-7:0) Since only the read is operating as lockless (outside of the "i_data_sem"), load tearing could introduce a logic bug. Fix it by adding READ_ONCE() for the read and WRITE_ONCE() for the write. Signed-off-by: Qian Cai Link: https://lore.kernel.org/r/1581085751-31793-1-git-send-email-cai@lca.pw Signed-off-by: Theodore Ts'o Cc: stable@kernel.org Signed-off-by: Greg Kroah-Hartman --- fs/ext4/ext4.h | 2 +- fs/ext4/inode.c | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) --- a/fs/ext4/ext4.h +++ b/fs/ext4/ext4.h @@ -2851,7 +2851,7 @@ static inline void ext4_update_i_disksiz !mutex_is_locked(&inode->i_mutex)); down_write(&EXT4_I(inode)->i_data_sem); if (newsize > EXT4_I(inode)->i_disksize) - EXT4_I(inode)->i_disksize = newsize; + WRITE_ONCE(EXT4_I(inode)->i_disksize, newsize); up_write(&EXT4_I(inode)->i_data_sem); } --- a/fs/ext4/inode.c +++ b/fs/ext4/inode.c @@ -2320,7 +2320,7 @@ update_disksize: * truncate are avoided by checking i_size under i_data_sem. */ disksize = ((loff_t)mpd->first_page) << PAGE_CACHE_SHIFT; - if (disksize > EXT4_I(inode)->i_disksize) { + if (disksize > READ_ONCE(EXT4_I(inode)->i_disksize)) { int err2; loff_t i_size;