Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp29287imu; Mon, 26 Nov 2018 16:37:31 -0800 (PST) X-Google-Smtp-Source: AFSGD/XoywEqVdBCbDLV9SCCcLJv/C3H45DITup8Q2EfdYCAYJ8iKU/elDvqRzJjuYts1buaHDx/ X-Received: by 2002:a17:902:bb98:: with SMTP id m24mr29479643pls.71.1543279051730; Mon, 26 Nov 2018 16:37:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543279051; cv=none; d=google.com; s=arc-20160816; b=AOYuSOFZv50hOQdpvQ/UY0QDCgvlQcGHU0qFDyeTaK4xqNMUQgTCc9ccXGELpA+tML Yqn0aTKGCGKd82fJOF9fjtfr6tk6MFqZf57ftfZRovpel7F4OLKHbGIObtsRWAJxKWXT 9Tq69AgUF21HwJ6Gh3ZQQpgA6DqBgJK8yVe77Gun5c27vyJ/n0iC3lOQEMt1gr5sPB7O 1xqmub2VtdDkd9khDFHsYCrEc9seOpRsNrwJU6dWcMVo6D8lA2dQ8dbahIAOUAEePXuu i0PdVqDvnI8BpUloXI8repCiiwIAdJZgC0BC+De7Y8qzK+7OzxICZXOjeoCf5DrEzeFs hjKg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=pILGacqwFxE2s3edWvIJ1QuH9Lszzm0YDswJvUE2GJU=; b=BQvGGcnLyuWkLWWRxKuHtABU+5m6Tb3/KR0o673IuS6SaQjShzhJ5Od8645dJVrcU/ b1W2I9vSnplg5yw9enOvJSvKHY1tdBBX9e2i3shytLClXimTtAb2K/+c7YsSSFxeD2Ra eg5JsgtRWOP9Wjs793f4cNDMJU75adXL/Vmay5P82ixCjEJgboGoYXiQlfLIEU/OPoGL 6yKtktRpaTNzaRsFJuhKSkA2sIzo69DSPwv+4+hgWH8MzvzXB6ong3hbR+FS9T+b/phF AbZj1ZihP3RSFOBIFeUIh9Z2MwW4vU0oTGPYph9jbewB7zYUqgfa8RG4YspkKgAqPWaI hkRA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@163.com header.s=s110527 header.b=Kwhz7LTV; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h32si1840474pgh.276.2018.11.26.16.37.16; Mon, 26 Nov 2018 16:37:31 -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; dkim=pass header.i=@163.com header.s=s110527 header.b=Kwhz7LTV; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727761AbeK0LbV (ORCPT + 99 others); Tue, 27 Nov 2018 06:31:21 -0500 Received: from m12-15.163.com ([220.181.12.15]:56401 "EHLO m12-15.163.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727456AbeK0LbV (ORCPT ); Tue, 27 Nov 2018 06:31:21 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=163.com; s=s110527; h=From:Subject:Date:Message-Id; bh=pILGacqwFxE2s3edWv IJ1QuH9Lszzm0YDswJvUE2GJU=; b=Kwhz7LTVZBqCUr45+aj3qq9mjc/tBjGMxG moZ2GCHsAhfFrsUNuB3BhPV4/M1tGJdqpK74q0yysfOKOUvTZoc19rJCvYRrorh2 krpravBR604mLwQ9GKjgP8tTMdKqPH9Q8vR6XW0VJhagssYRdg5jxVg/74OmXdTj 8LbWMfV+I= Received: from bp.localdomain (unknown [106.120.213.96]) by smtp11 (Coremail) with SMTP id D8CowADX6DHikPxbqYR1AA--.4456S3; Tue, 27 Nov 2018 08:33:40 +0800 (CST) From: Pan Bian To: "Darrick J. Wong" , Brian Foster , Dave Chinner , Carlos Maiolino , linux-xfs@vger.kernel.org Cc: linux-kernel@vger.kernel.org, Pan Bian Subject: [PATCH V2] xfs: libxfs: move xfs_perag_put late Date: Tue, 27 Nov 2018 08:33:38 +0800 Message-Id: <1543278818-117362-1-git-send-email-bianpan2016@163.com> X-Mailer: git-send-email 2.7.4 X-CM-TRANSID: D8CowADX6DHikPxbqYR1AA--.4456S3 X-Coremail-Antispam: 1Uf129KBjvdXoW7JFy7JF1rKw4kZF1UXF1UZFb_yoWDXrb_Ka 1xtFs7A34ktrW7J3W5Xws5t3WUtF4fG393uayfJFW3K34UGFn3ZwsrXrn0qFy3urWaqFZ8 W3yDGFW3Krya9jkaLaAFLSUrUUUUUb8apTn2vfkv8UJUUUU8Yxn0WfASr-VFAUDa7-sFnT 9fnUUvcSsGvfC2KfnxnUUI43ZEXa7IU8RuWJUUUUU== X-Originating-IP: [106.120.213.96] X-CM-SenderInfo: held01tdqsiiqw6rljoofrz/xtbBZBwMclQHCrrVeAAAsI Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The function xfs_alloc_get_freelist calls xfs_perag_put to drop the reference. However, pag->pagf_btreeblks is read and write after the put operation. This patch moves the put operation late. Signed-off-by: Pan Bian --- V2: correct the commit log --- fs/xfs/libxfs/xfs_alloc.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/fs/xfs/libxfs/xfs_alloc.c b/fs/xfs/libxfs/xfs_alloc.c index e1c0c0d..4be387d 100644 --- a/fs/xfs/libxfs/xfs_alloc.c +++ b/fs/xfs/libxfs/xfs_alloc.c @@ -2435,7 +2435,6 @@ xfs_alloc_get_freelist( be32_add_cpu(&agf->agf_flcount, -1); xfs_trans_agflist_delta(tp, -1); pag->pagf_flcount--; - xfs_perag_put(pag); logflags = XFS_AGF_FLFIRST | XFS_AGF_FLCOUNT; if (btreeblk) { @@ -2443,6 +2442,7 @@ xfs_alloc_get_freelist( pag->pagf_btreeblks++; logflags |= XFS_AGF_BTREEBLKS; } + xfs_perag_put(pag); xfs_alloc_log_agf(tp, agbp, logflags); *bnop = bno; -- 2.7.4