From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 0E72EC6FA89 for ; Mon, 12 Sep 2022 19:28:14 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 16DB794000A; Mon, 12 Sep 2022 15:28:11 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 0F812940008; Mon, 12 Sep 2022 15:28:11 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id E89B394000A; Mon, 12 Sep 2022 15:28:10 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0012.hostedemail.com [216.40.44.12]) by kanga.kvack.org (Postfix) with ESMTP id CE4B2940008 for ; Mon, 12 Sep 2022 15:28:10 -0400 (EDT) Received: from smtpin27.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay04.hostedemail.com (Postfix) with ESMTP id ABB0B1A1164 for ; Mon, 12 Sep 2022 19:28:10 +0000 (UTC) X-FDA: 79904419140.27.795FC8B Received: from mx0b-00082601.pphosted.com (mx0b-00082601.pphosted.com [67.231.153.30]) by imf13.hostedemail.com (Postfix) with ESMTP id 3D11520099 for ; Mon, 12 Sep 2022 19:28:10 +0000 (UTC) Received: from pps.filterd (m0148460.ppops.net [127.0.0.1]) by mx0a-00082601.pphosted.com (8.17.1.5/8.17.1.5) with ESMTP id 28CHMlLv003830 for ; Mon, 12 Sep 2022 12:28:09 -0700 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=fb.com; h=from : to : cc : subject : date : message-id : in-reply-to : references : mime-version : content-transfer-encoding : content-type; s=facebook; bh=OavFVzY5bttSht+NisTpXONRoLLq0g+z/0pTAeB2uZA=; b=nlLMGaWXuqIvMeMMLBz0b4FNMb3we+S6yQrcuFDBvEOTGnhWVZZGcHAGfVzBDzqF4AMc gucasGXRM9BQdDloi4nV0PBv05vmFR8zcwsRkDyP6VXspGnCvgFFYPgT/bAoRPQ0qDCR KwUv3khtkTjwKc42Yo9zWZPIIgNNHroP9GM= Received: from maileast.thefacebook.com ([163.114.130.16]) by mx0a-00082601.pphosted.com (PPS) with ESMTPS id 3jgr40mdta-4 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT) for ; Mon, 12 Sep 2022 12:28:09 -0700 Received: from twshared15978.04.prn5.facebook.com (2620:10d:c0a8:1b::d) by mail.thefacebook.com (2620:10d:c0a8:83::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Mon, 12 Sep 2022 12:28:07 -0700 Received: by dev1180.prn1.facebook.com (Postfix, from userid 425415) id 0A8C62085230; Mon, 12 Sep 2022 12:27:54 -0700 (PDT) From: Stefan Roesch To: , , , CC: , , , Subject: [PATCH v3 05/12] btrfs: add btrfs_try_lock_ordered_range Date: Mon, 12 Sep 2022 12:27:45 -0700 Message-ID: <20220912192752.3785061-6-shr@fb.com> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20220912192752.3785061-1-shr@fb.com> References: <20220912192752.3785061-1-shr@fb.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-FB-Internal: Safe Content-Type: text/plain X-Proofpoint-ORIG-GUID: o_MK4WZWL7o5zWoF3bI8-BUOlGdRWNm9 X-Proofpoint-GUID: o_MK4WZWL7o5zWoF3bI8-BUOlGdRWNm9 X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.205,Aquarius:18.0.895,Hydra:6.0.528,FMLib:17.11.122.1 definitions=2022-09-12_13,2022-09-12_02,2022-06-22_01 ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1663010890; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=OavFVzY5bttSht+NisTpXONRoLLq0g+z/0pTAeB2uZA=; b=wE75z45y4uNEfKvq6U+0bCOaeLNIsBc8YvIUy8H5PDcQg/tj+JdgWPIdvDnMH4kn/vS3QN m+kS78s16ycpUFjLCoYtxq4QHA9KLiJ2A4NIyQUorrr90DpGuHgGS1X7EPTjbkX8CauAT1 PKN7WgN2kGQzrUfXoc2aT+655X8OAUo= ARC-Authentication-Results: i=1; imf13.hostedemail.com; dkim=pass header.d=fb.com header.s=facebook header.b=nlLMGaWX; spf=pass (imf13.hostedemail.com: domain of "prvs=025416ff2e=shr@fb.com" designates 67.231.153.30 as permitted sender) smtp.mailfrom="prvs=025416ff2e=shr@fb.com"; dmarc=pass (policy=reject) header.from=fb.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1663010890; a=rsa-sha256; cv=none; b=Zv0mUvhnbfOgIwMHL825nh2Z56F9si+fKhg9mGwccmnCJzjFSRtl13iZEKJrNIiPJA4pn6 V1SnHdD0b7vmgLhkw4qHCZ1TaPyZaYE8TUn6AZLcYOYSXjvoyKZeHkFjVBjGxC3I5CV45F KS/rlJsZ5PY3/CEoOhhAWdw/EAKyX5I= X-Rspam-User: X-Stat-Signature: q93ht8j8wi9sf47785qe8eypti1ymh89 X-Rspamd-Queue-Id: 3D11520099 Authentication-Results: imf13.hostedemail.com; dkim=pass header.d=fb.com header.s=facebook header.b=nlLMGaWX; spf=pass (imf13.hostedemail.com: domain of "prvs=025416ff2e=shr@fb.com" designates 67.231.153.30 as permitted sender) smtp.mailfrom="prvs=025416ff2e=shr@fb.com"; dmarc=pass (policy=reject) header.from=fb.com X-Rspamd-Server: rspam04 X-HE-Tag: 1663010890-30603 X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: From: Josef Bacik For IOCB_NOWAIT we're going to want to use try lock on the extent lock, and simply bail if there's an ordered extent in the range because the only choice there is to wait for the ordered extent to complete. Signed-off-by: Josef Bacik Signed-off-by: Stefan Roesch --- fs/btrfs/ordered-data.c | 28 ++++++++++++++++++++++++++++ fs/btrfs/ordered-data.h | 1 + 2 files changed, 29 insertions(+) diff --git a/fs/btrfs/ordered-data.c b/fs/btrfs/ordered-data.c index 1952ac85222c..29c570f9a0ff 100644 --- a/fs/btrfs/ordered-data.c +++ b/fs/btrfs/ordered-data.c @@ -1041,6 +1041,34 @@ void btrfs_lock_and_flush_ordered_range(struct btr= fs_inode *inode, u64 start, } } =20 +/* + * btrfs_try_lock_ordered_range - lock the passed range and ensure all p= ending + * ordered extents in it are run to completion in nowait mode. + * + * @inode: Inode whose ordered tree is to be searched + * @start: Beginning of range to flush + * @end: Last byte of range to lock + * + * This function returns true if btrfs_lock_ordered_range does not retur= n any + * extents, otherwise false. + */ +bool btrfs_try_lock_ordered_range(struct btrfs_inode *inode, u64 start, = u64 end) +{ + struct btrfs_ordered_extent *ordered; + + if (!try_lock_extent(&inode->io_tree, start, end)) + return false; + + ordered =3D btrfs_lookup_ordered_range(inode, start, end - start + 1); + if (!ordered) + return true; + + btrfs_put_ordered_extent(ordered); + unlock_extent(&inode->io_tree, start, end); + return false; +} + + static int clone_ordered_extent(struct btrfs_ordered_extent *ordered, u6= 4 pos, u64 len) { diff --git a/fs/btrfs/ordered-data.h b/fs/btrfs/ordered-data.h index 87792f85e2c4..8edd4b2d3952 100644 --- a/fs/btrfs/ordered-data.h +++ b/fs/btrfs/ordered-data.h @@ -218,6 +218,7 @@ void btrfs_wait_ordered_roots(struct btrfs_fs_info *f= s_info, u64 nr, void btrfs_lock_and_flush_ordered_range(struct btrfs_inode *inode, u64 s= tart, u64 end, struct extent_state **cached_state); +bool btrfs_try_lock_ordered_range(struct btrfs_inode *inode, u64 start, = u64 end); int btrfs_split_ordered_extent(struct btrfs_ordered_extent *ordered, u64= pre, u64 post); int __init ordered_data_init(void); --=20 2.30.2