Received: by 10.223.176.46 with SMTP id f43csp4123822wra; Tue, 23 Jan 2018 04:45:37 -0800 (PST) X-Google-Smtp-Source: AH8x225fcu/N2pNy6oXpt6NB/KxUB/X0el4ndCLfcAwe6itYiGDC1cdFZJZ+LhyEgVdDdIM1EfW2 X-Received: by 2002:a17:902:f64:: with SMTP id 91-v6mr5384979ply.417.1516711537445; Tue, 23 Jan 2018 04:45:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516711537; cv=none; d=google.com; s=arc-20160816; b=nNmG8I/cz8AgRt93GYThYpSGkrnOX+kGS1YZEemGv/6bOz14JAXHOS7gLS26izrdGd kW6K/uvjevgKK5LhxqW481PrtRudMiPnX+g684nAKY8Tr/nmTh++FM8b1XudWfdO+ssa osq8TM0OswrM693i92+tkDbrQIho6TVDaC/8B/evx8h5DP+NGBNSr43JcrdZn67vzMh/ xydi8iwHKcWYvP/WmIaPyB4YUqFIdYUzfPyomkQS/uOFNnh8B0/w8AlM2PxiR8onJj/M ixxF03ksRIl227hQyRHIQBr3hPn1a5db/urZvUecOv4tq+dhe6Y8mYvl9AZtl06aBoON Q+GQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=hjnmC4fXwM73rTpk7SPHir9drUKyYh96kywPO5vTM/U=; b=dLkaG7N6QSScHrbJGJwwR5GYGj9gQgsEzu+kkDJ5hJOMVP2jWoEDj5SaSm67fy/2hA xphOUW/ah7OxtwEG564REjIgLvMh580b/fcrVS3fvySDQ2nhZcCIdW0ScjFIIab4oo3s HYAv43BAqAMMN/rpphfVV4L+acCAIGPZ2V6hSRoMz7pMOcvMZ/ol7logwFEKH3bXYmwV w3gG+7dwL6i1tksL1wSFbEKYCVPN7pJVYVXVk4aLPw0YckkEn80rbQ8HEDoFE/dSoO49 09DDZkOW3nnS9FE9m9z12fmA39GO9IW83A7WlUCG28xzdhaUfXbSd6hRMF/Hz7clI2pF ec5g== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 1-v6si4696933plp.678.2018.01.23.04.45.23; Tue, 23 Jan 2018 04:45:37 -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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751798AbeAWMnp (ORCPT + 99 others); Tue, 23 Jan 2018 07:43:45 -0500 Received: from mx1.redhat.com ([209.132.183.28]:35788 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751443AbeAWMnn (ORCPT ); Tue, 23 Jan 2018 07:43:43 -0500 Received: from smtp.corp.redhat.com (int-mx06.intmail.prod.int.phx2.redhat.com [10.5.11.16]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id D57E3BDEA; Tue, 23 Jan 2018 12:43:43 +0000 (UTC) Received: from localhost (unknown [10.18.25.149]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 6E4E217145; Tue, 23 Jan 2018 12:43:38 +0000 (UTC) Date: Tue, 23 Jan 2018 07:43:37 -0500 From: Mike Snitzer To: Ming Lei , Bart Van Assche Cc: Ming Lei , Jens Axboe , "dm-devel@redhat.com" , "linux-kernel@vger.kernel.org" , "hch@infradead.org" , "linux-block@vger.kernel.org" , "osandov@fb.com" Subject: Re: block: neutralize blk_insert_cloned_request IO stall regression (was: Re: [RFC PATCH] blk-mq: fixup RESTART when queue becomes idle) Message-ID: <20180123124337.GA24760@redhat.com> References: <20180118204856.GA31679@redhat.com> <1516309128.2676.38.camel@wdc.com> <20180118212327.GB31679@redhat.com> <1516311554.2676.50.camel@wdc.com> <20180118220132.GA20860@redhat.com> <1516314012.2676.76.camel@wdc.com> <20180123092204.GA39002@redhat.com> <20180123105357.GA3344@ming.t460p> <20180123121519.GA24681@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.21 (2010-09-15) X-Scanned-By: MIMEDefang 2.79 on 10.5.11.16 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.29]); Tue, 23 Jan 2018 12:43:43 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jan 23 2018 at 7:17am -0500, Ming Lei wrote: > On Tue, Jan 23, 2018 at 8:15 PM, Mike Snitzer wrote: > > On Tue, Jan 23 2018 at 5:53am -0500, > > Ming Lei wrote: > > > >> Hi Mike, > >> > >> On Tue, Jan 23, 2018 at 10:22:04AM +0100, Mike Snitzer wrote: > >> > > >> > From: Mike Snitzer > >> > Date: Tue, 23 Jan 2018 09:40:22 +0100 > >> > Subject: [PATCH] block: neutralize blk_insert_cloned_request IO stall regression > >> > > >> > The series of blk-mq changes intended to improve sequential IO > >> > performace (through improved merging with dm-mapth blk-mq stacked on > >> > underlying blk-mq device). Unfortunately these changes have caused > >> > dm-mpath blk-mq IO stalls when blk_mq_request_issue_directly()'s call to > >> > q->mq_ops->queue_rq() fails (due to device-specific resource > >> > unavailability). > >> > > >> > Fix this by reverting back to how blk_insert_cloned_request() functioned > >> > prior to commit 396eaf21ee -- by using blk_mq_request_bypass_insert() > >> > instead of blk_mq_request_issue_directly(). > >> > > >> > In the future, this commit should be reverted as the first change in a > >> > followup series of changes that implements a comprehensive solution to > >> > allowing an underlying blk-mq queue's resource limitation to trigger the > >> > upper blk-mq queue to run once that underlying limited resource is > >> > replenished. > >> > > >> > Fixes: 396eaf21ee ("blk-mq: improve DM's blk-mq IO merging via blk_insert_cloned_request feedback") > >> > Signed-off-by: Mike Snitzer > >> > --- > >> > block/blk-core.c | 3 ++- > >> > 1 file changed, 2 insertions(+), 1 deletion(-) > >> > > >> > diff --git a/block/blk-core.c b/block/blk-core.c > >> > index cdae69be68e9..a224f282b4a6 100644 > >> > --- a/block/blk-core.c > >> > +++ b/block/blk-core.c > >> > @@ -2520,7 +2520,8 @@ blk_status_t blk_insert_cloned_request(struct request_queue *q, struct request * > >> > * bypass a potential scheduler on the bottom device for > >> > * insert. > >> > */ > >> > - return blk_mq_request_issue_directly(rq); > >> > + blk_mq_request_bypass_insert(rq, true); > >> > + return BLK_STS_OK; > >> > } > >> > >> If this patch is for fixing IO stall on DM, it isn't needed, and actually > >> it can't fix the IO stall issue. > > > > It should "fix it" in conjunction with this: > > > > https://git.kernel.org/pub/scm/linux/kernel/git/device-mapper/linux-dm.git/commit/?h=dm-4.16&id=87b7e73546b55f4a3a37d4726daedd9a17a20509 > > > > (Bart already said as much, I just effectively enabled the equivalent of > > his reverts) > > If the generic solution is take, Bart's revert isn't needed. Yes, we need Bart to verify your v2 patch: https://patchwork.kernel.org/patch/10179945/ Bart please test this tree: https://git.kernel.org/pub/scm/linux/kernel/git/device-mapper/linux-dm.git/log/?h=for-next Please report back with your results (and include details on any changes you make to the tree, hopefully no changes are needed). Thanks, Mike