Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp53018pxb; Tue, 12 Apr 2022 16:34:36 -0700 (PDT) X-Google-Smtp-Source: ABdhPJywLxR056cTksJrTny5nWRr1DqV7tHtLpezqDkxCvRA6hqku4AFlMQLCQBh/TrHyxCAODjO X-Received: by 2002:a05:6a00:2444:b0:4fd:db81:cbdd with SMTP id d4-20020a056a00244400b004fddb81cbddmr6996188pfj.32.1649806475282; Tue, 12 Apr 2022 16:34:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649806475; cv=none; d=google.com; s=arc-20160816; b=m+WXbusuvFJ6hntpYNDgJJQgHfTOZ76EoScihfw4yJyCoU8kcP4xDOZRDKIs4M3Pgz q/FQo2/G8q6KgAu61imdhp7PK1cdzyjVgFX1mbst+Tt1m3uUkhSYRYeIpBVcJw+AFUly 3T/FsvY5TcX9hMZynKKeaqSEML8pvOU++6YhSzoqUOLRCp+apTyVBgl3SCjBBkgmnVah WRUm2rG3MZawAsFRwR1um4ECBWrC3em7W8yPMgtj3EPUbVl5oS6ugdzikXURQBfLtF5H v5VkRZ8t/BsBOWPWWc7qrFpr6446YbGJVVKaMBTt8NNixqHB0BITMMaUml+qzrEU+V3M 50Gw== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=WcFoMc/veLLoYxn4XxcOZF41jC1EjWO8Cu9Vhj79sFg=; b=uX17TsPOKxN9hRF83BM60pxjG6NvxDuk8qwc4ay8QoiV1CBfw4n0WKBARW/XgTKlv3 ODqMuioJEc3F+JQ2noSqfye9WJ4aZMDVmVbSZIfyF/f8kkVLSo+wBLegr9c6x6Athm8W H9XRo5E1VRPJLPSFFWdGvRcLVDya8sa4qFXbShfvjBBKW5CQQPtjty30TiGZ/POOToCY SFv29+IU7Z/H+cEdWW9ZEyyVSjbKLmSvA0dgWthClF74sPzizOpnB9/JmkBwJ1RS+OAw AANAGjZrvrORIqcdzZydfiUwRqtFptjfSCIxz82intsCfEoUS699bFpFcS0ekNQKqem0 4VTQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=K6vs034t; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id k13-20020a170902ce0d00b0015830f35108si13928806plg.209.2022.04.12.16.34.34 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 12 Apr 2022 16:34:35 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=K6vs034t; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 760EF1B29F2; Tue, 12 Apr 2022 14:25:36 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232005AbiDLI7s (ORCPT + 99 others); Tue, 12 Apr 2022 04:59:48 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50190 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1357086AbiDLHjq (ORCPT ); Tue, 12 Apr 2022 03:39:46 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4EE7B766A; Tue, 12 Apr 2022 00:11:36 -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 ams.source.kernel.org (Postfix) with ESMTPS id 00F55B81B55; Tue, 12 Apr 2022 07:11:35 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 4CD82C385A5; Tue, 12 Apr 2022 07:11:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1649747493; bh=cOJMjEz2leFlw3+iOtU0SQJpbPFauZMyUI2oO2RpbFY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=K6vs034tVjJRLMRcNkjMIZT+Hi9XUk/aCgCU85yDKlG+uTNmORxgyzpvzanZzW/eq lnxS89ivCVJM7t6fXho8b5HOR7+Q8Yh4Yr/QsJM5yqsWFeS/aD21j4TFXwHPHglIkM HLAVXfutqx0G2UY/tqCQ3wGBL8FD9tWWoggf58jQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Zhang Yi , Mike Snitzer , Sasha Levin Subject: [PATCH 5.17 098/343] dm: requeue IO if mapping table not yet available Date: Tue, 12 Apr 2022 08:28:36 +0200 Message-Id: <20220412062953.930612409@linuxfoundation.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220412062951.095765152@linuxfoundation.org> References: <20220412062951.095765152@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no 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 From: Mike Snitzer [ Upstream commit fa247089de9936a46e290d4724cb5f0b845600f5 ] Update both bio-based and request-based DM to requeue IO if the mapping table not available. This race of IO being submitted before the DM device ready is so narrow, yet possible for initial table load given that the DM device's request_queue is created prior, that it best to requeue IO to handle this unlikely case. Reported-by: Zhang Yi Signed-off-by: Mike Snitzer Signed-off-by: Sasha Levin --- drivers/md/dm-rq.c | 7 ++++++- drivers/md/dm.c | 11 +++-------- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/drivers/md/dm-rq.c b/drivers/md/dm-rq.c index 579ab6183d4d..dffeb47a9efb 100644 --- a/drivers/md/dm-rq.c +++ b/drivers/md/dm-rq.c @@ -499,8 +499,13 @@ static blk_status_t dm_mq_queue_rq(struct blk_mq_hw_ctx *hctx, if (unlikely(!ti)) { int srcu_idx; - struct dm_table *map = dm_get_live_table(md, &srcu_idx); + struct dm_table *map; + map = dm_get_live_table(md, &srcu_idx); + if (unlikely(!map)) { + dm_put_live_table(md, srcu_idx); + return BLK_STS_RESOURCE; + } ti = dm_table_find_target(map, 0); dm_put_live_table(md, srcu_idx); } diff --git a/drivers/md/dm.c b/drivers/md/dm.c index 394778d8bf54..dcb8d8fc7877 100644 --- a/drivers/md/dm.c +++ b/drivers/md/dm.c @@ -1519,15 +1519,10 @@ static void dm_submit_bio(struct bio *bio) struct dm_table *map; map = dm_get_live_table(md, &srcu_idx); - if (unlikely(!map)) { - DMERR_LIMIT("%s: mapping table unavailable, erroring io", - dm_device_name(md)); - bio_io_error(bio); - goto out; - } - /* If suspended, queue this IO for later */ - if (unlikely(test_bit(DMF_BLOCK_IO_FOR_SUSPEND, &md->flags))) { + /* If suspended, or map not yet available, queue this IO for later */ + if (unlikely(test_bit(DMF_BLOCK_IO_FOR_SUSPEND, &md->flags)) || + unlikely(!map)) { if (bio->bi_opf & REQ_NOWAIT) bio_wouldblock_error(bio); else if (bio->bi_opf & REQ_RAHEAD) -- 2.35.1