Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp810757pxb; Tue, 12 Apr 2022 14:05:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw3Xvx/JK7oeM2WYKZUsMdSbTeTlUNtk1AFRWlR7A6txUpb1NUzc5j/XwnxwVD59Y+cvaMa X-Received: by 2002:a05:6a00:27a2:b0:4fa:e893:bb68 with SMTP id bd34-20020a056a0027a200b004fae893bb68mr39910065pfb.82.1649797544464; Tue, 12 Apr 2022 14:05:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649797544; cv=none; d=google.com; s=arc-20160816; b=E0tjXbERPTfXsiAJfFqn/fv5DB13AOu07K6FbgSY2vL1pyQ+qUTLQ7OLSysMdek6+3 NcGikFA6k7TsEd0zjCp/wfDAbtPyHzdxyah0IJH+fy8GtNXxS6r1qlbKevBSrpO2/3g0 3AiRysH/ncX+K1i6AMhAK1GMs2EzHcLNSnrnAXkVAp5m1uqjy7XrpblmQfPWEa3/K9WO H8Z9Kmba4/hnEvwl4QCDax2DwHgOEceJOVa/DyOlzbNtQ7rH/RoVikWx2zZtkLz45qev D4EBPiYrGrKi0m1CzeiIg7mrv+XGKREhnh8WgQsy7v/ZaH5vWFh+NKGGtUKAQmbTlXRN f1kg== 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=jue5muIiS8KdjgE+mzFYrfY0rbZdjc2zvZhyg6oBSKY=; b=VgVBZxaueEVGNCc9IT/4ceuIV2/5PgS0uBJBOuDZp8LyDIiR4QhaxF0lSe1/FCdP1h NXBAzzGcYeMltD26PyVFUcBHROM/YCEd8xEhOElOaOEgLN9h/DOj2sEPpFKCkS0qIuiA qzH3IJiNe8vkWecORZE0SmErqdes+W7IusuPxPW0R7kL8Cah6TghyI0odBsn41vEaslZ MSDVPPvoAk/8tGsKXuPgAw0OW0ZomQsu36/rXkonGB0seNCjFmaupmNTsiskuwFgPrfY TqySl1kW4vxevF7Jg7NCTbnM+782EgzRX7y+CdJkX3nx/roDRFhGRNY/Lp2m2BiOa5cw Ru4g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=MUveFP+B; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 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. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id k17-20020a056a00169100b004fa9a8cc0ccsi13294816pfc.100.2022.04.12.14.05.43 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 12 Apr 2022 14:05:44 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=MUveFP+B; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 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 C3643DE85; Tue, 12 Apr 2022 13:24:53 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1358383AbiDLHld (ORCPT + 99 others); Tue, 12 Apr 2022 03:41:33 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45944 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1353460AbiDLHPZ (ORCPT ); Tue, 12 Apr 2022 03:15:25 -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 990E639815; Mon, 11 Apr 2022 23:56:58 -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 E0F86B81B43; Tue, 12 Apr 2022 06:56:56 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 369C0C385A8; Tue, 12 Apr 2022 06:56:55 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1649746615; bh=CS2I9ncH29T565J8Zn6hf9xZSmGn45aldAFGwM5euAQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=MUveFP+BnptWxLf1BOgTjqNVZKHuYsFFUXbf5p0KnX1eqSLnZuM6m8vmlPb2nPSpk gp+zggk9y5DHn53Fc6FQ+JH3Q2mQN/nfq/JQ43Lu6bemdz/d0Y91Ygp3iZCVqiKFtO ODRVF2QbkQtP9uutNxTuCXsudXMpRMSVSM6bpylA= 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.16 067/285] dm: requeue IO if mapping table not yet available Date: Tue, 12 Apr 2022 08:28:44 +0200 Message-Id: <20220412062945.603417875@linuxfoundation.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220412062943.670770901@linuxfoundation.org> References: <20220412062943.670770901@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 5fd3660e07b5..af12c0accb59 100644 --- a/drivers/md/dm.c +++ b/drivers/md/dm.c @@ -1587,15 +1587,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