Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3027676imu; Mon, 19 Nov 2018 09:33:03 -0800 (PST) X-Google-Smtp-Source: AJdET5cty7yb7FJQ9BZ7ULb3KnDh908hvNSIFQQhlcxNk0LdzkGMbm0GQ+XmPMqSvC17np8gtMBP X-Received: by 2002:a63:7f4f:: with SMTP id p15mr20952956pgn.296.1542648783696; Mon, 19 Nov 2018 09:33:03 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542648783; cv=none; d=google.com; s=arc-20160816; b=w1Q2Z7bC51S4psq0ZRiPJpZwFdAPceWB0YT6G59dl3sPJB5jztjSH8jq7cPBzqYGDI 2t7StncAJI+kM4EE92BDg/OM8gqnEOLvp/ggiQv5nGRBDAJ7CN5+7OyaKsJHYeGiTa0t d7j6I7f70APd3J+wkZssmNLjdAg4avvVpLc7rMC/prNimUx61wtWLT34esCTKnvzY7wk XadIla4dMCB4fwrBNV5TUI6rtU8QCllAaah8DZVQS+i5NC6hz6sDhsHuaHIyLdMn+da2 WrFMwLAjV+M4JdBcGMH6Dtql9dk4CuhDWxMrFJTUeI0ZhecCIscg6EqIqtdPsPhNRkTc hxUQ== 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=Aw74OA1r7IPQIQ8FR13tbegVb8oNpSb+V9Q/OcW4Cjw=; b=lw2h1LVfwZwSnAQcZw9S28UPXJt3HCjfln45Yc7WnKVixbD9zG79GP9tIo6l2gwbZ9 vwl5d3n0JLQrj4Dt0i8uOk/vwxUwZ2gPB4ohKH0QxeMxRqo3Pb8VHYI06YLgwMTsu1xu VytlTtrrkYNQUqq97tEgALhDgEXfFBc8oKGRU8IFiNqUQV9u3Tlr8q/O+vqcyY3Ziqpb TyFJ8NWgWtbz4liX8K9sQ+ZAWpgKb03HkhBcRvJnv7ADbkBYvxjyV6EpVlN9Wcue4wuC FpC6Up8FoUrXYVJrVa8zSSCf42+zLi51XAzis8mhn3PXx59GkVyZ9ZGkCnq0Uh7E9jpR bSmQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=FO0ygtmF; 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 t69si39386902pgb.365.2018.11.19.09.32.47; Mon, 19 Nov 2018 09:33:03 -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=FO0ygtmF; 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 S2391007AbeKTDSx (ORCPT + 99 others); Mon, 19 Nov 2018 22:18:53 -0500 Received: from mail.kernel.org ([198.145.29.99]:57872 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390256AbeKTDSv (ORCPT ); Mon, 19 Nov 2018 22:18:51 -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 6115F2145D; Mon, 19 Nov 2018 16:54:37 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1542646477; bh=/oK+uPW9hqMEhDqmeVSmBAeDCNn6h783z5TMDW1cCWQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=FO0ygtmFAFdviI2ToiBALRmwbPLolVazHCS1b1nx/LOhKLfroTSGhC0uj2/1KiN/A 1fv0MBvjIv1Mh6PI9iZJWTY100N9vvENN/4BiFZK1T2GLOO7d6kHNb1JgAdCfND328 5ELBuZ2ZUw/FbFqT2mkp8WH6o4hDeb0OCxEWdRAE= 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.9 56/83] ext4: avoid potential extra brelse in setup_new_flex_group_blocks() Date: Mon, 19 Nov 2018 17:29:22 +0100 Message-Id: <20181119162623.437008554@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181119162612.046511542@linuxfoundation.org> References: <20181119162612.046511542@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.9-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 @@ -590,7 +590,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); @@ -602,9 +601,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) @@ -619,18 +618,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++) { @@ -661,7 +658,6 @@ handle_ib: } out: - brelse(bh); err2 = ext4_journal_stop(handle); if (err2 && !err) err = err2;