Received: by 10.213.65.68 with SMTP id h4csp1671557imn; Mon, 19 Mar 2018 10:09:59 -0700 (PDT) X-Google-Smtp-Source: AG47ELvhtmRNBkrYBCUo20DxRaHkfKvIfj8romMY5Xu5PBFNLbj7RR+IcjOsHCcdFr2eGJVKBlbw X-Received: by 10.99.44.22 with SMTP id s22mr9689440pgs.111.1521479399264; Mon, 19 Mar 2018 10:09:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521479399; cv=none; d=google.com; s=arc-20160816; b=vxeg0tGuFg4l0C5vrARJhFXEquwxYMwsjBCZh7o/awvsZzWodWXAN5NuSIPJEWbtU7 pUGkGyfjFFJsEtfkt5PRZBTwZVo3BJkVEoq8evNRZDbr4Qf+tYJl9uMExuE+tmwMPFV6 4Tr790bEVViBbh5GAygWKXvL2BfCANHEevzMXGZp04E2XrLtde8L2JOSiwtlRHBh+Cjx nghvaHVaiNAKtc3d4/H3iXBVK6m3PgA2yxJxZIqcSHGfwQu+33rYfXFTIj/SZOnBxDD1 qOcXDz/LCfO0/FEzPP7AKkqY5nDeMXXIKXD916siXPgML+gwB2rOs5RpAgp2yur+JuBe Jrlw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :spamdiagnosticmetadata:spamdiagnosticoutput:content-language :accept-language:in-reply-to:references:message-id:date:thread-index :thread-topic:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=ifsRV9VbKOcTl1ZfKn2sprYVzbmDcg22MO1vaH2sWD8=; b=WDt0cBzcEjDMWnSwlOSdM+fk7Ks54rf5DMbJVYtnm2/8p7Ewf8zRDzUtaL57WwYUa/ eBECtEyIfrsvNPiTr9EQ1SX5ZwUf6/0TrRD2k2hkLEX5/0sTV5dvQfpIOcYoSxov3MMW 5DVCwc/ev9NUAi+qpk22UajhEv1ftenW9h6SQSD9SN1ySQkyx24S6VGSrmHVKUtt+eCJ e/WAigcBHhF0y5WGC/+JCRT1o/EBRsT7LonyAQE3YalxBXzhwimzaVRcbTtViueszgTl jiuddEg++ayBhuGezIsI+Vjp88FCuMSXAUWOYgBYlw7v8otNSe/nQzB+7aE87c5j2/UA PqBA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@microsoft.com header.s=selector1 header.b=N9rSnkNE; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=microsoft.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a13si233941pgd.36.2018.03.19.10.09.44; Mon, 19 Mar 2018 10:09:59 -0700 (PDT) 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; dkim=pass header.i=@microsoft.com header.s=selector1 header.b=N9rSnkNE; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=microsoft.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S967599AbeCSRHb (ORCPT + 99 others); Mon, 19 Mar 2018 13:07:31 -0400 Received: from mail-co1nam03on0115.outbound.protection.outlook.com ([104.47.40.115]:37952 "EHLO NAM03-CO1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S966487AbeCSQKt (ORCPT ); Mon, 19 Mar 2018 12:10:49 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=ifsRV9VbKOcTl1ZfKn2sprYVzbmDcg22MO1vaH2sWD8=; b=N9rSnkNEMT55pPxvPIifTk8OWCrBE8lNhYg1mhWtM5RGsVFhKD1nS8KbGxLfg86bYNIN3z0o4TJrTd4ObIJj6mBlHvEI0fpvN4U/2UjQYNwU1Iyk2i6/8Ho5sWL0ICGZ6muIP5MiX9MBc/sM55omo7gI2QYoYpdqWo/mgBF7dIc= Received: from DM5PR2101MB1032.namprd21.prod.outlook.com (52.132.128.13) by DM5PR2101MB0888.namprd21.prod.outlook.com (52.132.132.157) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.631.0; Mon, 19 Mar 2018 16:10:44 +0000 Received: from DM5PR2101MB1032.namprd21.prod.outlook.com ([fe80::3d9b:79e7:94eb:5d62]) by DM5PR2101MB1032.namprd21.prod.outlook.com ([fe80::3d9b:79e7:94eb:5d62%5]) with mapi id 15.20.0631.004; Mon, 19 Mar 2018 16:10:44 +0000 From: Sasha Levin To: "linux-kernel@vger.kernel.org" , "stable@vger.kernel.org" CC: James Wang , Jens Axboe , Sasha Levin Subject: [PATCH AUTOSEL for 4.4 138/167] Fix loop device flush before configure v3 Thread-Topic: [PATCH AUTOSEL for 4.4 138/167] Fix loop device flush before configure v3 Thread-Index: AQHTv5x9WY2xEyGkBkeHysJJyvvBNg== Date: Mon, 19 Mar 2018 16:08:15 +0000 Message-ID: <20180319160513.16384-138-alexander.levin@microsoft.com> References: <20180319160513.16384-1-alexander.levin@microsoft.com> In-Reply-To: <20180319160513.16384-1-alexander.levin@microsoft.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-originating-ip: [52.168.54.252] x-ms-publictraffictype: Email x-microsoft-exchange-diagnostics: 1;DM5PR2101MB0888;7:cCSHU0k8OfT1z+NvWc80NC36WndekHZviOAs0u3Tm4sCCXLqa5Lv4dR4aKrFPq9Sjd9ZHsSYXnYLdUxonhb8H+eSwpLXREqOUbTfUIYFY6YsZ/rL8+N4TlmwBFTLA1FLJBYMxi94MUg1qUpyQYv5Q7QERGywMPt7eDTZ6Dn9xEwuXz5t7969T8tUJupBM8EQ4S8hrD4jw2OKCtolLf27RndSh98wDQ/LiJqCLf2FFO9nVhVqwQUb4V25XuUzVQXV;20:V15jRsCxW0BBi9F/TcNjxrPPxZwDVakbeaOR38wqs13vcmEthYgMufh/QoXXcrTV9TMpY7I2rhZYnlWTDenphRL0nV9RrxL0edhyYbWOgOUWbU1lqYiAgbm5S2M7PJQgquhxxFlvtEMBzBX9WCIDhIDpsigIXRsnjdyJ6iXNyyU= x-ms-office365-filtering-ht: Tenant x-ms-office365-filtering-correlation-id: 417761ac-73cb-4ef5-2b6e-08d58db3f812 x-microsoft-antispam: UriScan:;BCL:0;PCL:0;RULEID:(7020095)(4652020)(48565401081)(5600026)(4604075)(3008032)(4534165)(4627221)(201703031133081)(201702281549075)(2017052603328)(7193020);SRVR:DM5PR2101MB0888; x-ms-traffictypediagnostic: DM5PR2101MB0888: authentication-results: spf=none (sender IP is ) smtp.mailfrom=Alexander.Levin@microsoft.com; x-microsoft-antispam-prvs: x-exchange-antispam-report-test: UriScan:(28532068793085)(26323138287068)(89211679590171)(67672495146484); x-exchange-antispam-report-cfa-test: BCL:0;PCL:0;RULEID:(8211001083)(61425038)(6040522)(2401047)(5005006)(8121501046)(3231221)(944501300)(52105095)(3002001)(93006095)(93001095)(10201501046)(6055026)(61426038)(61427038)(6041310)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123560045)(20161123562045)(20161123564045)(20161123558120)(6072148)(201708071742011);SRVR:DM5PR2101MB0888;BCL:0;PCL:0;RULEID:;SRVR:DM5PR2101MB0888; x-forefront-prvs: 06167FAD59 x-forefront-antispam-report: SFV:NSPM;SFS:(10019020)(396003)(346002)(39860400002)(366004)(39380400002)(376002)(189003)(199004)(54534003)(6486002)(72206003)(106356001)(86362001)(3660700001)(6436002)(68736007)(53936002)(107886003)(8936002)(81166006)(8676002)(81156014)(2906002)(6116002)(4326008)(6512007)(1076002)(86612001)(66066001)(25786009)(7736002)(3846002)(305945005)(5660300001)(99286004)(5250100002)(110136005)(478600001)(36756003)(54906003)(2501003)(6506007)(186003)(26005)(14454004)(6666003)(2900100001)(316002)(2950100002)(102836004)(10290500003)(3280700002)(97736004)(76176011)(10090500001)(22452003)(105586002)(22906009)(217873001);DIR:OUT;SFP:1102;SCL:1;SRVR:DM5PR2101MB0888;H:DM5PR2101MB1032.namprd21.prod.outlook.com;FPR:;SPF:None;LANG:en;PTR:InfoNoRecords;MX:1;A:1; received-spf: None (protection.outlook.com: microsoft.com does not designate permitted sender hosts) x-microsoft-antispam-message-info: BXX39PbsrVh0pKeGP8lXov/BYVJB5mqonXP+E671H7d+Fd8rc2FuY51Cvea1qFhC3t6U0/Kxeazaz26ZztnyVjQwjsEASs48xf4L+on6X8jcSWXmXHdfZRznKxya3UubNP/AOZkqJsRtjK4nxN76JNgvGkOskIfw27kbQjiHjw1rTz3AOlASFT9ah+gw5ielnFjLL3HmgkYkHTQ+4yVYs1hDdkWUA48v5SMkuk3KDmTmoIWLVuBaV0ZoEQ8Mh5aF/34yBoQrJ4rS2d7Z07jpFyf6Y3atMDQALcym11eM98/SkKcnLT3KnW3QZ1vCS26PiD/k935Nfn9Dts2FwJQgeQ== spamdiagnosticoutput: 1:99 spamdiagnosticmetadata: NSPM Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-OriginatorOrg: microsoft.com X-MS-Exchange-CrossTenant-Network-Message-Id: 417761ac-73cb-4ef5-2b6e-08d58db3f812 X-MS-Exchange-CrossTenant-originalarrivaltime: 19 Mar 2018 16:08:15.9274 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 72f988bf-86f1-41af-91ab-2d7cd011db47 X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM5PR2101MB0888 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: James Wang [ Upstream commit 6460495709aeb651896bc8e5c134b2e4ca7d34a8 ] While installing SLES-12 (based on v4.4), I found that the installer will stall for 60+ seconds during LVM disk scan. The root cause was determined to be the removal of a bound device check in loop_flush() by commit b5dd2f6047ca ("block: loop: improve performance via blk-mq"). Restoring this check, examining ->lo_state as set by loop_set_fd() eliminates the bad behavior. Test method: modprobe loop max_loop=3D64 dd if=3D/dev/zero of=3Ddisk bs=3D512 count=3D200K for((i=3D0;i<4;i++))do losetup -f disk; done mkfs.ext4 -F /dev/loop0 for((i=3D0;i<4;i++))do mkdir t$i; mount /dev/loop$i t$i;done for f in `ls /dev/loop[0-9]*|sort`; do \ echo $f; dd if=3D$f of=3D/dev/null bs=3D512 count=3D1; \ done Test output: stock patched /dev/loop0 18.1217e-05 8.3842e-05 /dev/loop1 6.1114e-05 0.000147979 /dev/loop10 0.414701 0.000116564 /dev/loop11 0.7474 6.7942e-05 /dev/loop12 0.747986 8.9082e-05 /dev/loop13 0.746532 7.4799e-05 /dev/loop14 0.480041 9.3926e-05 /dev/loop15 1.26453 7.2522e-05 Note that from loop10 onward, the device is not mounted, yet the stock kernel consumes several orders of magnitude more wall time than it does for a mounted device. (Thanks for Mike Galbraith , give a changelog review.) Reviewed-by: Hannes Reinecke Reviewed-by: Ming Lei Signed-off-by: James Wang Fixes: b5dd2f6047ca ("block: loop: improve performance via blk-mq") Signed-off-by: Jens Axboe Signed-off-by: Sasha Levin --- drivers/block/loop.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/drivers/block/loop.c b/drivers/block/loop.c index 1c36de9719e5..d02afeb11197 100644 --- a/drivers/block/loop.c +++ b/drivers/block/loop.c @@ -623,6 +623,9 @@ static int loop_switch(struct loop_device *lo, struct f= ile *file) */ static int loop_flush(struct loop_device *lo) { + /* loop not yet configured, no running thread, nothing to flush */ + if (lo->lo_state !=3D Lo_bound) + return 0; return loop_switch(lo, NULL); } =20 --=20 2.14.1