Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp797373rwl; Fri, 31 Mar 2023 02:29:44 -0700 (PDT) X-Google-Smtp-Source: AKy350a7UBZh3DyC/RZmWnnZiLt5Fymwh1oAyJ6Q+y7KBqtqKk81D+gSTTs/eEghh+oQM/ZBwefe X-Received: by 2002:a17:903:264b:b0:196:8d96:dc6b with SMTP id je11-20020a170903264b00b001968d96dc6bmr5596749plb.2.1680254984714; Fri, 31 Mar 2023 02:29:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680254984; cv=none; d=google.com; s=arc-20160816; b=hNIXjRF/I+dWorbcysVxpw3annkotJtV4wnU9B5dL7XPZtlBjaG0/5W4pLtuqxHLQ1 VI0dlK7Gv8Rl8xM+bcfEu2/6jrz/GzIIpx7p3e43UAN2tKpOpn77rwiEaChQjspMZrjX p8lpec5VKByUS9T8aGR3NWsU8ZgfewSITVlfGLSn9z9L488+NjzlQcwCzDzbPxrVU6jz 30SksDKq2RUGxs2Zmh0xaNQsX6LyAB2ZE5s4jOiDlhBIFGli1XnfeP5cGEvLkh/e0eE3 GH+WaKnDqveltmewHLtV+RYA7phcGv3CoKxI4+OV8Vrytkm0uIRW863XXcgHdMC+WgZ3 lePQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from :dkim-signature; bh=avL8CU6kY5CS4NKIn08+zcUBC0UI/MDg7QxLShqe7BY=; b=vKSwaKngkJgAteIhNRhKlCj4dA9V2UU6gnX8CVaYoy4TzeRSNyyrMQ0U2OaGdbrxHu hsjK3EXMsg4eYrSMLy5Pn9+FSFfYdMQlBRjlrCBtRPfbe4oPslitVTkYI1v0x6V5WYTa AddjPVTDrqhr5J9DxTFTwrLfeGwDsvzS8aK3KFW7QXHgmxBPyeLYAj/l7coTcf7bEo2L 0BTgCgLjbFa4x6FfggxvEd+qU9v0Ms3b2G+l3mO0nB/m+aI7yyhKDywU1cgLRDmoFhmK G5RoTCJBO5s54sRaXW7gTgL9UVjTrnkABVL9d7Ym4wi0iivNW9iSiaOFClKuom3t2R4Q Oj7A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mediatek.com header.s=dk header.b=aRLXWOtf; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=mediatek.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id b10-20020a170903228a00b001a076305275si1843481plh.318.2023.03.31.02.29.33; Fri, 31 Mar 2023 02:29:44 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@mediatek.com header.s=dk header.b=aRLXWOtf; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=mediatek.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232227AbjCaJ2q (ORCPT + 99 others); Fri, 31 Mar 2023 05:28:46 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56322 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232195AbjCaJ2X (ORCPT ); Fri, 31 Mar 2023 05:28:23 -0400 Received: from mailgw02.mediatek.com (unknown [210.61.82.184]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3C48C1E732 for ; Fri, 31 Mar 2023 02:27:53 -0700 (PDT) X-UUID: 3413c18ccfa611edb6b9f13eb10bd0fe-20230331 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=mediatek.com; s=dk; h=Content-Type:MIME-Version:Message-ID:Date:Subject:CC:To:From; bh=avL8CU6kY5CS4NKIn08+zcUBC0UI/MDg7QxLShqe7BY=; b=aRLXWOtfC9pfQlrLiiVitZq7A9juNIhcu8H9DoRQ1gzuQ4/xPZsN17/an3iMuvQiX8iPxnr8wFQPB2siAwY8XvldVFDsK2ATVo+J7pcK+OT/AtzN2zH6Dk7sjIrGp3GJFCaLpORy9TQitex6E746XLuB/B/UldCSm35StA0axNc=; X-CID-P-RULE: Release_Ham X-CID-O-INFO: VERSION:1.1.22,REQID:2b5f194f-a467-4a30-b95b-bb9c29408ed7,IP:0,U RL:0,TC:0,Content:0,EDM:0,RT:0,SF:0,FILE:0,BULK:0,RULE:Release_Ham,ACTION: release,TS:0 X-CID-META: VersionHash:120426c,CLOUDID:e5f6f6b4-beed-4dfc-bd9c-e1b22fa6ccc4,B ulkID:nil,BulkQuantity:0,Recheck:0,SF:102,TC:nil,Content:0,EDM:-3,IP:nil,U RL:11|1,File:nil,Bulk:nil,QS:nil,BEC:nil,COL:0,OSI:0,OSA:0,AV:0 X-CID-BVR: 0,NGT X-CID-BAS: 0,NGT,0,_ X-UUID: 3413c18ccfa611edb6b9f13eb10bd0fe-20230331 Received: from mtkmbs11n2.mediatek.inc [(172.21.101.187)] by mailgw02.mediatek.com (envelope-from ) (Generic MTA with TLSv1.2 ECDHE-RSA-AES256-GCM-SHA384 256/256) with ESMTP id 255766054; Fri, 31 Mar 2023 17:27:06 +0800 Received: from mtkmbs13n1.mediatek.inc (172.21.101.193) by mtkmbs11n1.mediatek.inc (172.21.101.185) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1118.25; Fri, 31 Mar 2023 17:27:05 +0800 Received: from mcddlt001.gcn.mediatek.inc (10.19.240.15) by mtkmbs13n1.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.2.1118.25 via Frontend Transport; Fri, 31 Mar 2023 17:27:04 +0800 From: Bo Ye To: Jaegeuk Kim , Chao Yu , Matthias Brugger , AngeloGioacchino Del Regno CC: , , , , Qilin Tan , , , , Subject: [PATCH 1/2] f2fs: fix iostat lock protection Date: Fri, 31 Mar 2023 17:26:56 +0800 Message-ID: <20230331092658.72386-1-bo.ye@mediatek.com> X-Mailer: git-send-email 2.17.0 MIME-Version: 1.0 Content-Type: text/plain X-Spam-Status: No, score=-0.2 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_MSPIKE_H2,SPF_HELO_PASS, T_SPF_TEMPERROR,UNPARSEABLE_RELAY autolearn=unavailable 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: Qilin Tan Made iostat lock irq safe to avoid potentinal deadlock. Deadlock scenario: f2fs_attr_store -> f2fs_sbi_store -> _sbi_store -> spin_lock(sbi->iostat_lock) -> scsi_end_request -> bio_endio -> f2fs_dio_read_end_io -> f2fs_update_iostat -> spin_lock_irqsave(sbi->iostat_lock) ===> Dead lock here Signed-off-by: Qilin Tan --- fs/f2fs/sysfs.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/fs/f2fs/sysfs.c b/fs/f2fs/sysfs.c index 0b19163c90d4..fd238a68017e 100644 --- a/fs/f2fs/sysfs.c +++ b/fs/f2fs/sysfs.c @@ -575,9 +575,9 @@ static ssize_t __sbi_store(struct f2fs_attr *a, if (!strcmp(a->attr.name, "iostat_period_ms")) { if (t < MIN_IOSTAT_PERIOD_MS || t > MAX_IOSTAT_PERIOD_MS) return -EINVAL; - spin_lock(&sbi->iostat_lock); + spin_lock_irq(&sbi->iostat_lock); sbi->iostat_period_ms = (unsigned int)t; - spin_unlock(&sbi->iostat_lock); + spin_unlock_irq(&sbi->iostat_lock); return count; } #endif -- 2.17.0