Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp1355532pxf; Fri, 12 Mar 2021 07:47:27 -0800 (PST) X-Google-Smtp-Source: ABdhPJzBYbT06GPxAWKnBEwag73C/EAWl4lyZxpQ8ncZDD3eGubLIf6/rjo6eqPyrijLDcNMzBf3 X-Received: by 2002:aa7:c78e:: with SMTP id n14mr14778765eds.31.1615564046842; Fri, 12 Mar 2021 07:47:26 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1615564046; cv=none; d=google.com; s=arc-20160816; b=pxAEkJvtI4Jy59pfqsJ3gTFLqcQWRP41YYM1Z61FuE1DnoVBRW+R+hQ/z1HLnbUu3y kZbfcgnm8dYHd1CLXYV6Kkcnq8lZ/DJZsgvkFnESO7wdTuFevBUUe03jfT9WxtPiVUr8 s6UVoGSEsAQiUDNebu8iV8PfYBE/vHxtJ2mp9tnpLXE2mOT6fP9ctWiK56D0816oJ1x6 sVLHnqN/F/vzocXtPGbnenB27nNl3h0rQ8NrrRG2UuNBMS+g41gvgq9i+3mXilpbNed2 efNhzy5xUQa0Qb71R0PfAJ/CX3Nk6KMrzpgc8YhUI7SLMJMEAkcXzRxvH75J1x2KWiIb eMjA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=E7vklZS3KQKvlQW65s1wvDn6+2dH/1XjVlF3nm5Ihtk=; b=LECpVvjwOxglYAO7kEq0eL/2+WtxcHFzmtAsGd95F2ig2jVcophRXyFkF9ROBoPvxL IqUfshVknAdU4SmmnKjpnq1SvdT7g43/swTLs32HpvKO9znEer+c/HIk/aO3Kq08nASB OxieVcHY18QcJDM6iSfuAgdUYTQYQ8SlTWU//xan9P9RhSWcqsIhLIOJctO5ZLR6NRN+ gqnI6q5bDaSA1EGDCVn+6djaIUqC1y0RhUb9zq0Er0uk63NR4ymikPBVgu7E+EL7O2be E2MbFXKvyyZeuNEtRs/NSn5/XNZXkit5FhizBpdUCvYgCWnlycTi8O08PpKruGlXisK5 BgOg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@veeam.com header.s=mx4 header.b=SdtDNGUA; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=veeam.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bt20si4473790edb.201.2021.03.12.07.47.04; Fri, 12 Mar 2021 07:47:26 -0800 (PST) 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=@veeam.com header.s=mx4 header.b=SdtDNGUA; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=veeam.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233365AbhCLPp4 (ORCPT + 99 others); Fri, 12 Mar 2021 10:45:56 -0500 Received: from mx4.veeam.com ([104.41.138.86]:49948 "EHLO mx4.veeam.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232583AbhCLPpV (ORCPT ); Fri, 12 Mar 2021 10:45:21 -0500 Received: from mail.veeam.com (prgmbx01.amust.local [172.24.0.171]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mx4.veeam.com (Postfix) with ESMTPS id C04F1114A90; Fri, 12 Mar 2021 18:45:17 +0300 (MSK) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=veeam.com; s=mx4; t=1615563917; bh=E7vklZS3KQKvlQW65s1wvDn6+2dH/1XjVlF3nm5Ihtk=; h=From:To:CC:Subject:Date:In-Reply-To:References:From; b=SdtDNGUABLkZFqgXedaW5RLH3FOTjPK8hBnQe3Hc/iMoyHErKJ+DD1rc8rjM7ouV6 TFcQ5frFhf4IULEwLTohxz51zG0cgCtZ35Jvvm8aHkszbiLwOhfPvPtrcDdBRUsPOy D9QdwhbxiQlJXnBSgkTajzEienrF87YoWlr/Qu8A= Received: from prgdevlinuxpatch01.amust.local (172.24.14.5) by prgmbx01.amust.local (172.24.0.171) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.721.2; Fri, 12 Mar 2021 16:45:15 +0100 From: Sergei Shtepa To: Christoph Hellwig , Mike Snitzer , Alasdair Kergon , Hannes Reinecke , Jens Axboe , , , , CC: , Subject: [PATCH v7 1/3] block: add blk_mq_is_queue_frozen() Date: Fri, 12 Mar 2021 18:44:53 +0300 Message-ID: <1615563895-28565-2-git-send-email-sergei.shtepa@veeam.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1615563895-28565-1-git-send-email-sergei.shtepa@veeam.com> References: <1615563895-28565-1-git-send-email-sergei.shtepa@veeam.com> MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [172.24.14.5] X-ClientProxiedBy: prgmbx02.amust.local (172.24.0.172) To prgmbx01.amust.local (172.24.0.171) X-EsetResult: clean, is OK X-EsetId: 37303A29D2A50B58627366 X-Veeam-MMEX: True Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org blk_mq_is_queue_frozen() allow to assert that the queue is frozen. Signed-off-by: Sergei Shtepa --- block/blk-mq.c | 13 +++++++++++++ include/linux/blk-mq.h | 1 + 2 files changed, 14 insertions(+) diff --git a/block/blk-mq.c b/block/blk-mq.c index d4d7c1caa439..2f188a865024 100644 --- a/block/blk-mq.c +++ b/block/blk-mq.c @@ -161,6 +161,19 @@ int blk_mq_freeze_queue_wait_timeout(struct request_queue *q, } EXPORT_SYMBOL_GPL(blk_mq_freeze_queue_wait_timeout); +bool blk_mq_is_queue_frozen(struct request_queue *q) +{ + bool frozen; + + mutex_lock(&q->mq_freeze_lock); + frozen = percpu_ref_is_dying(&q->q_usage_counter) && + percpu_ref_is_zero(&q->q_usage_counter); + mutex_unlock(&q->mq_freeze_lock); + + return frozen; +} +EXPORT_SYMBOL_GPL(blk_mq_is_queue_frozen); + /* * Guarantee no request is in use, so we can change any data structure of * the queue afterward. diff --git a/include/linux/blk-mq.h b/include/linux/blk-mq.h index 2c473c9b8990..6f01971abf7b 100644 --- a/include/linux/blk-mq.h +++ b/include/linux/blk-mq.h @@ -533,6 +533,7 @@ void blk_freeze_queue_start(struct request_queue *q); void blk_mq_freeze_queue_wait(struct request_queue *q); int blk_mq_freeze_queue_wait_timeout(struct request_queue *q, unsigned long timeout); +bool blk_mq_is_queue_frozen(struct request_queue *q); int blk_mq_map_queues(struct blk_mq_queue_map *qmap); void blk_mq_update_nr_hw_queues(struct blk_mq_tag_set *set, int nr_hw_queues); -- 2.20.1