Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp2225302rwb; Fri, 11 Nov 2022 06:44:43 -0800 (PST) X-Google-Smtp-Source: AA0mqf5dNB/nWnamE1HBkCrIkdxzZ8baBLBzZDH7lDe/GBeFlLYnHWWjTnSjFU3oKQlpKFg+Dykh X-Received: by 2002:a17:906:1597:b0:7ad:ba48:7e7f with SMTP id k23-20020a170906159700b007adba487e7fmr2040703ejd.215.1668177883448; Fri, 11 Nov 2022 06:44:43 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1668177883; cv=none; d=google.com; s=arc-20160816; b=uE/nNO715DeKfhEDEpRdVAtnAk5PFwZaLjvJYJWKuTpbqeKaK5A6zD2C/BhM1JTsg2 go1ZHyzxNcG3jwl5u+mLidk613hsdBduGHgXqYEqWH/hzjRs2kELASrJuZ2ilzKfTRmw Pk3g6pao4jHqNQLjgO4bhG0Oq0XCURIEXHznqvXu8FgKDQOiILhJ83I9GmA6Y7PnS8k2 IJ/Y/SGrmyHDoO/OUYqt2/aWpb0c4Y30n1Wp4ODlPzyx7Pdr9uXgU41GDGOklm8ZChy4 w53Esfy0/uNMmU2Wd3hE8SdISpRSnQKR25t5nRpi3dqQ2baX3BmnQ6OEUUjqNkPqg/+V h0Iw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature :dkim-signature; bh=D3UIxZQpc5Ytr6eLo8bbfQvKg2R72Jo8To0qXRFhxGg=; b=XHh31Th7qoxfEoEJenAu5/7ULgZ0gMWCFhoezbYDqFBAIKHBCHgRliahNKcc1u2fAf 3zDcOxzcP1Eqhwp8TiHMzEAZql4kdDlfPu57qqDElV5kvQ6VSFu3dj9jKVrWVc/+J3aQ HQP5ra2KEfBXSE4t7nk0ukO+PwzM/TvuM7H2n/dAahl7BMXm6/9arTM0eskjT4FjdrPv P4tOXOakq4b3RdRBmjBIBoyo2hcT+WOjDyca5RwicdyFV0ON7KAEEThkftPxGw3XRfET 5GMZLtheYLgN/EZotiBuEUKnp5F61qJ7I3rcPwUaIImbOX56LJ/9gsrDNlyL6RvyyiLz C4UA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.cz header.s=susede2_rsa header.b=vF9Q1xBI; dkim=neutral (no key) header.i=@suse.cz; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-ext4-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 js6-20020a17090797c600b0073dda1430b9si2220994ejc.403.2022.11.11.06.44.10; Fri, 11 Nov 2022 06:44:43 -0800 (PST) Received-SPF: pass (google.com: domain of linux-ext4-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=@suse.cz header.s=susede2_rsa header.b=vF9Q1xBI; dkim=neutral (no key) header.i=@suse.cz; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-ext4-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234146AbiKKOZP (ORCPT + 99 others); Fri, 11 Nov 2022 09:25:15 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36960 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233908AbiKKOY1 (ORCPT ); Fri, 11 Nov 2022 09:24:27 -0500 Received: from smtp-out1.suse.de (smtp-out1.suse.de [195.135.220.28]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 533BD9FC8 for ; Fri, 11 Nov 2022 06:24:26 -0800 (PST) Received: from imap2.suse-dmz.suse.de (imap2.suse-dmz.suse.de [192.168.254.74]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (P-521) server-digest SHA512) (No client certificate requested) by smtp-out1.suse.de (Postfix) with ESMTPS id 10C252241A; Fri, 11 Nov 2022 14:24:25 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.cz; s=susede2_rsa; t=1668176665; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=D3UIxZQpc5Ytr6eLo8bbfQvKg2R72Jo8To0qXRFhxGg=; b=vF9Q1xBIamw/b3ud1m7fiJckcFCrB1T6ZqqVvoydy4H+kkx4GnCAkpKwWumUf3KVTPRRJZ GeuXuxK6jJuuzk1zJm/ZaJwAgxENd3GeKf/rt6WZbF5wgMIE+2ql6YgV7ZUT5HODaSLXtd Pc8nhZZBNk/xyRJASrXz5hEO1zmTLek= DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=suse.cz; s=susede2_ed25519; t=1668176665; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=D3UIxZQpc5Ytr6eLo8bbfQvKg2R72Jo8To0qXRFhxGg=; b=lYfvr+bwt2vv+/FDs0e/uW9q2QcbV4zq7qeCxt5GrEioT6+tfAur67EKaZ/XUDWKsxee8T C1Ur7gxmMrs27oBg== Received: from imap2.suse-dmz.suse.de (imap2.suse-dmz.suse.de [192.168.254.74]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (P-521) server-digest SHA512) (No client certificate requested) by imap2.suse-dmz.suse.de (Postfix) with ESMTPS id 0227B13357; Fri, 11 Nov 2022 14:24:25 +0000 (UTC) Received: from dovecot-director2.suse.de ([192.168.254.65]) by imap2.suse-dmz.suse.de with ESMTPSA id REx9ABlbbmM2DgAAMHmgww (envelope-from ); Fri, 11 Nov 2022 14:24:25 +0000 Received: by quack3.suse.cz (Postfix, from userid 1000) id 8866CA06F6; Fri, 11 Nov 2022 15:24:24 +0100 (CET) Date: Fri, 11 Nov 2022 15:24:24 +0100 From: Jan Kara To: Jeremi Piotrowski Cc: Jan Kara , Thilo Fromm , Ye Bin , jack@suse.com, tytso@mit.edu, linux-ext4@vger.kernel.org, regressions@lists.linux.dev Subject: Re: [syzbot] possible deadlock in jbd2_journal_lock_updates Message-ID: <20221111142424.vwt4khbtfzd5foiy@quack3> References: <20221010142410.GA1689@linuxonhyperv3.guj3yctzbm1etfxqx2vob5hsef.xx.internal.cloudapp.net> <2ede5fce-7077-6e64-93a9-a7d993bc498f@linux.microsoft.com> <20221014132543.i3aiyx4ent4qwy4i@quack3> <20221024104628.ozxjtdrotysq2haj@quack3> <643d007e-1041-4b3d-ed5e-ae47804f279d@linux.microsoft.com> <20221026101854.k6qgunxexhxthw64@quack3> <20221110125758.GA6919@linuxonhyperv3.guj3yctzbm1etfxqx2vob5hsef.xx.internal.cloudapp.net> <20221110152637.g64p4hycnd7bfnnr@quack3> <20221110192701.GA29083@linuxonhyperv3.guj3yctzbm1etfxqx2vob5hsef.xx.internal.cloudapp.net> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="c4cf2aow43ugq76v" Content-Disposition: inline In-Reply-To: <20221110192701.GA29083@linuxonhyperv3.guj3yctzbm1etfxqx2vob5hsef.xx.internal.cloudapp.net> X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,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-ext4@vger.kernel.org --c4cf2aow43ugq76v Content-Type: text/plain; charset=us-ascii Content-Disposition: inline On Thu 10-11-22 11:27:01, Jeremi Piotrowski wrote: > On Thu, Nov 10, 2022 at 04:26:37PM +0100, Jan Kara wrote: > > On Thu 10-11-22 04:57:58, Jeremi Piotrowski wrote: > > > On Wed, Oct 26, 2022 at 12:18:54PM +0200, Jan Kara wrote: > > > > On Mon 24-10-22 18:32:51, Thilo Fromm wrote: > > > > > Hello Honza, > > > > > > > > > > > Yeah, I was pondering about this for some time but still I have no clue who > > > > > > could be holding the buffer lock (which blocks the task holding the > > > > > > transaction open) or how this could related to the commit you have > > > > > > identified. I have two things to try: > > > > > > > > > > > > 1) Can you please check whether the deadlock reproduces also with 6.0 > > > > > > kernel? The thing is that xattr handling code in ext4 has there some > > > > > > additional changes, commit 307af6c8793 ("mbcache: automatically delete > > > > > > entries from cache on freeing") in particular. > > > > > > > > > > This would be complex; we currently do not integrate 6.0 with Flatcar and > > > > > would need to spend quite some effort ingesting it first (mostly, make sure > > > > > the new kernel does not break something unrelated). Flatcar is an > > > > > image-based distro, so kernel updates imply full distro updates. > > > > > > > > OK, understood. > > > > > > > > > > 2) I have created a debug patch (against 5.15.x stable kernel). Can you > > > > > > please reproduce the failure with it and post the output of "echo w > > > > > > > /proc/sysrq-trigger" and also the output the debug patch will put into the > > > > > > kernel log? It will dump the information about buffer lock owner if we > cannot get the lock for more than 32 seconds. > > > > > > > > > > This would be more straightforward - I can reach out to one of our users > > > > > suffering from the issue; they can reliably reproduce it and don't shy away > > > > > from patching their kernel. Where can I find the patch? > > > > > > > > Ha, my bad. I forgot to attach it. Here it is. > > > > > > > > > > Unfortunately this patch produced no output, but I have been able to repro so I > > > understand why: except for the hung tasks, we have 1+ tasks busy-looping through > > > the following code in ext4_xattr_block_set(): > > > > > > inserted: > > > if (!IS_LAST_ENTRY(s->first)) { > > > new_bh = ext4_xattr_block_cache_find(inode, header(s->base), > > > &ce); > > > if (new_bh) { > > > /* We found an identical block in the cache. */ > > > if (new_bh == bs->bh) > > > ea_bdebug(new_bh, "keeping"); > > > else { > > > u32 ref; > > > > > > WARN_ON_ONCE(dquot_initialize_needed(inode)); > > > > > > /* The old block is released after updating > > > the inode. */ > > > error = dquot_alloc_block(inode, > > > EXT4_C2B(EXT4_SB(sb), 1)); > > > if (error) > > > goto cleanup; > > > BUFFER_TRACE(new_bh, "get_write_access"); > > > error = ext4_journal_get_write_access( > > > handle, sb, new_bh, > > > EXT4_JTR_NONE); > > > if (error) > > > goto cleanup_dquot; > > > lock_buffer(new_bh); > > > /* > > > * We have to be careful about races with > > > * adding references to xattr block. Once we > > > * hold buffer lock xattr block's state is > > > * stable so we can check the additional > > > * reference fits. > > > */ > > > ref = le32_to_cpu(BHDR(new_bh)->h_refcount) + 1; > > > if (ref > EXT4_XATTR_REFCOUNT_MAX) { > > > /* > > > * Undo everything and check mbcache > > > * again. > > > */ > > > unlock_buffer(new_bh); > > > dquot_free_block(inode, > > > EXT4_C2B(EXT4_SB(sb), > > > 1)); > > > brelse(new_bh); > > > mb_cache_entry_put(ea_block_cache, ce); > > > ce = NULL; > > > new_bh = NULL; > > > goto inserted; > > > } > > > > > > The tasks keep taking the 'goto inserted' branch, and never finish. I've been > > > able to repro with kernel v6.0.7 as well. > > > > Interesting! That makes is much clearer (and also makes my debug patch > > unnecessary). So clearly the e_reusable variable in the mb_cache_entry got > > out of sync with the number of references really in the xattr block - in > > particular the block likely has h_refcount >= EXT4_XATTR_REFCOUNT_MAX but > > e_reusable is set to true. Now I can see how e_reusable can stay at false due > > to a race when refcount is actually smaller but I don't see how it could > > stay at true when refcount is big enough - that part seems to be locked > > properly. If you can reproduce reasonably easily, can you try reproducing > > with attached patch? Thanks! > > > > Sure, with that patch I'm getting the following output, reusable is false on > most items until we hit something with reusable true and then that loops > indefinitely: Thanks. So that is what I've suspected. I'm still not 100% clear on how this inconsistency can happen although I have a suspicion - does attached patch fix the problem for you? Also is it possible to share the reproducer or it needs some special infrastructure? Honza -- Jan Kara SUSE Labs, CR --c4cf2aow43ugq76v Content-Type: text/x-patch; charset=us-ascii Content-Disposition: attachment; filename="0001-ext4-Lock-xattr-buffer-before-inserting-cache-entry.patch" From 6132433e400ff7be348fe04fdf8ee67eb105ec21 Mon Sep 17 00:00:00 2001 From: Jan Kara Date: Thu, 10 Nov 2022 16:22:06 +0100 Subject: [PATCH] ext4: Lock xattr buffer before inserting cache entry --- fs/ext4/xattr.c | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c index 36d6ba7190b6..02e265bb94e2 100644 --- a/fs/ext4/xattr.c +++ b/fs/ext4/xattr.c @@ -2970,15 +2970,18 @@ ext4_xattr_block_cache_insert(struct mb_cache *ea_block_cache, struct buffer_head *bh) { struct ext4_xattr_header *header = BHDR(bh); - __u32 hash = le32_to_cpu(header->h_hash); - int reusable = le32_to_cpu(header->h_refcount) < - EXT4_XATTR_REFCOUNT_MAX; + __u32 hash; + int reusable; int error; if (!ea_block_cache) return; + lock_buffer(bh); + hash = le32_to_cpu(header->h_hash); + reusable = le32_to_cpu(header->h_refcount) < EXT4_XATTR_REFCOUNT_MAX; error = mb_cache_entry_create(ea_block_cache, GFP_NOFS, hash, bh->b_blocknr, reusable); + unlock_buffer(bh); if (error) { if (error == -EBUSY) ea_bdebug(bh, "already in cache"); -- 2.35.3 --c4cf2aow43ugq76v--