Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp679142ybz; Fri, 1 May 2020 06:41:14 -0700 (PDT) X-Google-Smtp-Source: APiQypK4ZqWcjsTC2FtC9iYZjNvlpYUrZ1H2zQNk+5ZuZRILeQqVvIA0Dqxhk/9hCYYd+Yjsvd56 X-Received: by 2002:a50:9e6a:: with SMTP id z97mr3346219ede.375.1588340474319; Fri, 01 May 2020 06:41:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588340474; cv=none; d=google.com; s=arc-20160816; b=j76oMrtHvb16zyRyIUmyGM9UqaSrWwd7ZqTDA03E2Nep+c1ULDZDwcE8E/c/RgZ8ND W0sEXbJj7OLcdS18N46lfTBduUM/coavSHo/r8m/dgyfChCUXgjSGDylQgRueqOux2kJ jdRgwbB9CLeLvuIZvcuCmMn5pPaqBrN2Vpa8WY5wRBUmMtcLKJ9B0JOrVdqzI1cxapho +JsU6sEh3Iu6Zj389vSSZt34WVZMdUznq3+qNTVtj6jgg+zBmIQQyKhNyeNru1yOuOB/ k5bH9RMwNPRKeSrKsDXU2mY9iJdmsmvMJdIw1Nle8eyDq6JkkYMYm0qTDRmmqsy+aI5a 2sHQ== 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=abQ3jiJsGsCWYnKW8tV5le5Uv11gl1WTzqGPVlI+vBM=; b=H0iWpYKUQ1R/EwyfVg5nd1oFO2dMMgBWs1tanip30nf0eVI3lxJ0L0iGii4zqz+qmO yT5Nk3zEAlSBtFz8gryYnmT5Hi1ABam+LBpLQ+FAmakBoYOD7Lxh3yGyqr5x77uuDNdc fOuTKjUxRUE3/u63jRbrdn/KUwC7d8xfd9XWwEYrvCAIkOE2CIb/l9Lczb31H6sXnwFI rATtHebWbS2aX+LQ4lMt/sCYevVd40iEX5xr3QWCUSt/1WJowv192b42yJgNxXPZuNRL K3UP22wgKcD9tBIN0Wzn/enGJNhp0h/tTSiGobivsdRoCO//4Ha1yXgeBgWhUL3IBe/v yiuw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=s6+aJyfN; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d11si1510658edy.477.2020.05.01.06.40.50; Fri, 01 May 2020 06:41:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=s6+aJyfN; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730909AbgEANgx (ORCPT + 99 others); Fri, 1 May 2020 09:36:53 -0400 Received: from mail.kernel.org ([198.145.29.99]:35508 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730902AbgEANgv (ORCPT ); Fri, 1 May 2020 09:36:51 -0400 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 E240324953; Fri, 1 May 2020 13:36:49 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1588340210; bh=tU8TJhxBIWcjE1Am1/vlBCvgrjTH7SCZbgZ7JE4Qicw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=s6+aJyfNSzN0zAlBMG4e+mpxV/FIXW1hMmFPC02Qy+5CuPWYFd5iAeuBc+lJxIkLF 2d3deSTjJza4AeR3s7U5yEag28XdM/lYxSfjmpIH0R6ZU2C8aXMB7nNmJ3ASYjp99P XSjZdmUANVCBBB6ttlmhqOX8iflJ5xBFyUkt+muU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, syzbot+e27980339d305f2dbfd9@syzkaller.appspotmail.com, Yang Shi , Andrew Morton , Hugh Dickins , Andrea Arcangeli , Linus Torvalds Subject: [PATCH 4.19 25/46] mm: shmem: disable interrupt when acquiring info->lock in userfaultfd_copy path Date: Fri, 1 May 2020 15:22:50 +0200 Message-Id: <20200501131507.682072631@linuxfoundation.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200501131457.023036302@linuxfoundation.org> References: <20200501131457.023036302@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: Yang Shi commit 94b7cc01da5a3cc4f3da5e0ff492ef008bb555d6 upstream. Syzbot reported the below lockdep splat: WARNING: possible irq lock inversion dependency detected 5.6.0-rc7-syzkaller #0 Not tainted -------------------------------------------------------- syz-executor.0/10317 just changed the state of lock: ffff888021d16568 (&(&info->lock)->rlock){+.+.}, at: spin_lock include/linux/spinlock.h:338 [inline] ffff888021d16568 (&(&info->lock)->rlock){+.+.}, at: shmem_mfill_atomic_pte+0x1012/0x21c0 mm/shmem.c:2407 but this lock was taken by another, SOFTIRQ-safe lock in the past: (&(&xa->xa_lock)->rlock#5){..-.} and interrupts could create inverse lock ordering between them. other info that might help us debug this: Possible interrupt unsafe locking scenario: CPU0 CPU1 ---- ---- lock(&(&info->lock)->rlock); local_irq_disable(); lock(&(&xa->xa_lock)->rlock#5); lock(&(&info->lock)->rlock); lock(&(&xa->xa_lock)->rlock#5); *** DEADLOCK *** The full report is quite lengthy, please see: https://lore.kernel.org/linux-mm/alpine.LSU.2.11.2004152007370.13597@eggly.anvils/T/#m813b412c5f78e25ca8c6c7734886ed4de43f241d It is because CPU 0 held info->lock with IRQ enabled in userfaultfd_copy path, then CPU 1 is splitting a THP which held xa_lock and info->lock in IRQ disabled context at the same time. If softirq comes in to acquire xa_lock, the deadlock would be triggered. The fix is to acquire/release info->lock with *_irq version instead of plain spin_{lock,unlock} to make it softirq safe. Fixes: 4c27fe4c4c84 ("userfaultfd: shmem: add shmem_mcopy_atomic_pte for userfaultfd support") Reported-by: syzbot+e27980339d305f2dbfd9@syzkaller.appspotmail.com Signed-off-by: Yang Shi Signed-off-by: Andrew Morton Tested-by: syzbot+e27980339d305f2dbfd9@syzkaller.appspotmail.com Acked-by: Hugh Dickins Cc: Andrea Arcangeli Link: http://lkml.kernel.org/r/1587061357-122619-1-git-send-email-yang.shi@linux.alibaba.com Signed-off-by: Linus Torvalds Signed-off-by: Greg Kroah-Hartman --- mm/shmem.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) --- a/mm/shmem.c +++ b/mm/shmem.c @@ -2350,11 +2350,11 @@ static int shmem_mfill_atomic_pte(struct lru_cache_add_anon(page); - spin_lock(&info->lock); + spin_lock_irq(&info->lock); info->alloced++; inode->i_blocks += BLOCKS_PER_PAGE; shmem_recalc_inode(inode); - spin_unlock(&info->lock); + spin_unlock_irq(&info->lock); inc_mm_counter(dst_mm, mm_counter_file(page)); page_add_file_rmap(page, false);