Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2976024imu; Mon, 19 Nov 2018 08:52:23 -0800 (PST) X-Google-Smtp-Source: AJdET5e9X5iZ6WKAuWE9XvdXMs2jXdHLOzRtMKue+hCQx8cimky05pumtu/bATNHxLy3B4Y90RgT X-Received: by 2002:a65:520a:: with SMTP id o10mr21557838pgp.276.1542646343218; Mon, 19 Nov 2018 08:52:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542646343; cv=none; d=google.com; s=arc-20160816; b=LENHxZZNygFRupAtHrJw3dzhAU8qdVjX+ye+2n1QwFIq08peVceMcu4XzkX5u3AjVi xut0dfWYR4su9e1apiCsAbySgHVS04rRCsBVVeMwQcv7TMuparFU582bDiCxY+EjjBX3 M+az8/6+Jnu1nIsoikJl8l+T87B93QkKaRQKrG3oAzbPwAPGDBwtyyctrkVbMmJHG3t5 CyiT/k2YW8KNvambH8j1QVX5DTS0/v3NISGZSdx5LFe3xCis34eVFooBABzNiHMe7t05 sidn1x18+VkOv+LLAWtq/Y5R3Oa4QQZH1TvkZwZIp79QP+ihAY/rvgBxK1zyJTPU9Y7V HqwQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=y24fMezk1Opm6ue9V0h37xzELh3B457tOGxGoySEoXM=; b=M42wDqgBD1eRbm4bHxAFypfbER3vMioTa1HW6t34NzO+KBUSgQbq9H1JbNcqH+d5rp gC+4yesykudQUFl7pPHogamYuopPDXc/nXCBlLIOe0iUQ38VqJTBQyQP3eBbDHZmOtaF MT9Fwj3PzaM3dAtr/hTmjRIXS1n+STMLp6W1+lHKi/cW5Od1SjS7azKQ+1oCobgt9gEl 11F9G28i3fRc/efbRFevOzA/Furr1I9gn/NigfCHBAk5ddmOrjRcQy1eMh+1b+uCtlkA pzw3K9b+2tdxV+zc+ZXhc4Iij1mNsHGrHMLsQzK4WkTZWWvrkvmnom+KzWf8YIFpFBFF QxGA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=P0hPGsQ9; 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 h6si25035799plk.231.2018.11.19.08.52.08; Mon, 19 Nov 2018 08:52:23 -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=@kernel.org header.s=default header.b=P0hPGsQ9; 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 S2390243AbeKTDP2 (ORCPT + 99 others); Mon, 19 Nov 2018 22:15:28 -0500 Received: from mail.kernel.org ([198.145.29.99]:53060 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388976AbeKTDP1 (ORCPT ); Mon, 19 Nov 2018 22:15:27 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 1DE43208E4; Mon, 19 Nov 2018 16:51:13 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1542646274; bh=+VzS/jqQlJvdAYUByv3/unY8V8Aw5MD9GnXdI2FzgBU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=P0hPGsQ9BfUw1NScCpUApILLEhX2hMl0HccvzE2pZJ74l7kUF1l3DLDpa+BL7VMIv KRTaBwHAZAkAVXJV6uRUrSiMUQBHzbTL9faFprk6AlYS4jmk9r+PJC88cKr5yTZ5OS mjNRcPWRFhnbk8/R8BFfiJj29uUt/cugkGIOxDrc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Vasily Averin , Theodore Tso , stable@kernel.org Subject: [PATCH 4.14 076/124] ext4: avoid potential extra brelse in setup_new_flex_group_blocks() Date: Mon, 19 Nov 2018 17:28:50 +0100 Message-Id: <20181119162627.703035071@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181119162612.951907286@linuxfoundation.org> References: <20181119162612.951907286@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.14-stable review patch. If anyone has any objections, please let me know. ------------------ From: Vasily Averin commit 9e4028935cca3f9ef9b6a90df9da6f1f94853536 upstream. Currently bh is set to NULL only during first iteration of for cycle, then this pointer is not cleared after end of using. Therefore rollback after errors can lead to extra brelse(bh) call, decrements bh counter and later trigger an unexpected warning in __brelse() Patch moves brelse() calls in body of cycle to exclude requirement of brelse() call in rollback. Fixes: 33afdcc5402d ("ext4: add a function which sets up group blocks ...") Signed-off-by: Vasily Averin Signed-off-by: Theodore Ts'o Cc: stable@kernel.org # 3.3+ Signed-off-by: Greg Kroah-Hartman --- fs/ext4/resize.c | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) --- a/fs/ext4/resize.c +++ b/fs/ext4/resize.c @@ -592,7 +592,6 @@ handle_bb: bh = bclean(handle, sb, block); if (IS_ERR(bh)) { err = PTR_ERR(bh); - bh = NULL; goto out; } overhead = ext4_group_overhead_blocks(sb, group); @@ -604,9 +603,9 @@ handle_bb: ext4_mark_bitmap_end(group_data[i].blocks_count, sb->s_blocksize * 8, bh->b_data); err = ext4_handle_dirty_metadata(handle, NULL, bh); + brelse(bh); if (err) goto out; - brelse(bh); handle_ib: if (bg_flags[i] & EXT4_BG_INODE_UNINIT) @@ -621,18 +620,16 @@ handle_ib: bh = bclean(handle, sb, block); if (IS_ERR(bh)) { err = PTR_ERR(bh); - bh = NULL; goto out; } ext4_mark_bitmap_end(EXT4_INODES_PER_GROUP(sb), sb->s_blocksize * 8, bh->b_data); err = ext4_handle_dirty_metadata(handle, NULL, bh); + brelse(bh); if (err) goto out; - brelse(bh); } - bh = NULL; /* Mark group tables in block bitmap */ for (j = 0; j < GROUP_TABLE_COUNT; j++) { @@ -663,7 +660,6 @@ handle_ib: } out: - brelse(bh); err2 = ext4_journal_stop(handle); if (err2 && !err) err = err2;