Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1365591pxb; Fri, 22 Jan 2021 13:58:51 -0800 (PST) X-Google-Smtp-Source: ABdhPJw0fkf62EovFRT3VIciGfMtu77z2jUPcjX65Xqpcpns1xRL8rKMqM4gFNpaEbguUl0jJFQ6 X-Received: by 2002:a17:906:a008:: with SMTP id p8mr4414715ejy.117.1611352731351; Fri, 22 Jan 2021 13:58:51 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611352731; cv=none; d=google.com; s=arc-20160816; b=IirHMBBlya09dlOfEiUZaOIe6KdBU9BvXyiTEdgkUkvf1xdC1a2xIBXx8vduaZ1L8c 2pmmqQuRYK6y6vqeMIqW1yxWZERKfUmUh+nDYYwbTLN6MO1fpivwV4YuggZWFQKomUPL oH7TzGONSw/27rlwiPjixeNMs6WnZnko8PQ/w3BP77z8YKl4aVflEHEbXPVbxOqb+/IQ v7LH1KNL+UKeC+nK1Gsg9Sa3gEY8rrvCvpT+f77rjym9rsSH6pyGT08OXRkUw/AYFhXw Ox6Zx0UmlMaqGVJexZ0md8L4vTH53X5Y0cyoIUQVyhpWxy3cCci7AK+3wEq5mtIE+316 N/wA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=gdwJXo4CPi5JTGgY08ra+aAnUR7uoLfwdatg+I3pl/k=; b=GAtQZzwNa2r5xtSSoFc++yfnSDKgGtp+H1EwWqjkZBzLvPe3V+q8IqwSl1rrffA1fG 7+3OBPLf538/T4dBWDqXcj2Z2x5IPK3NM0wOV1xKXJcgJfU7K/08EemQUKZQ3obp9tZF TycD8vcba7Rs2Pq+kusLSYd4mv/d6NGPUJL1LPFG3aiVmdiZgermBPHsJ2VtRnadbBFu QMEgUOwEYKvxZBWkbf15b+HypDr8V64ZOmjk+mQwXrGT1uHIYBkw0vz/tnjui3Q4d07a 0xibQ1WXtD+37Kcxb5FPHjnbteC1CUOA22lfVbkxJNY671NZGY17I2glt4eWcbZiTr0g 3iwQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u22si3467835ejc.544.2021.01.22.13.58.26; Fri, 22 Jan 2021 13:58:51 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730270AbhAVVuK (ORCPT + 99 others); Fri, 22 Jan 2021 16:50:10 -0500 Received: from lilium.sigma-star.at ([109.75.188.150]:32918 "EHLO lilium.sigma-star.at" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729347AbhAVVb6 (ORCPT ); Fri, 22 Jan 2021 16:31:58 -0500 Received: from localhost (localhost [127.0.0.1]) by lilium.sigma-star.at (Postfix) with ESMTP id 2197D181CBE08; Fri, 22 Jan 2021 22:22:36 +0100 (CET) Received: from lilium.sigma-star.at ([127.0.0.1]) by localhost (lilium.sigma-star.at [127.0.0.1]) (amavisd-new, port 10032) with ESMTP id 8QZnjaY9GVmZ; Fri, 22 Jan 2021 22:22:35 +0100 (CET) Received: from lilium.sigma-star.at ([127.0.0.1]) by localhost (lilium.sigma-star.at [127.0.0.1]) (amavisd-new, port 10026) with ESMTP id 5sE-lpCPrN4m; Fri, 22 Jan 2021 22:22:35 +0100 (CET) From: Richard Weinberger To: linux-mtd@lists.infradead.org Cc: david@sigma-star.at, richard@nod.at, linux-kernel@vger.kernel.org Subject: [PATCH 4/4] ubifs: Harden ubifs_jnl_write_inode() Date: Fri, 22 Jan 2021 22:22:29 +0100 Message-Id: <20210122212229.17072-5-richard@nod.at> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20210122212229.17072-1-richard@nod.at> References: <20210122212229.17072-1-richard@nod.at> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Make sure that ubifs_jnl_write_inode() cannot be abused and will not write less data then expected. Signed-off-by: Richard Weinberger --- fs/ubifs/journal.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/fs/ubifs/journal.c b/fs/ubifs/journal.c index 03410ae0813a..1b28fcc5b9fe 100644 --- a/fs/ubifs/journal.c +++ b/fs/ubifs/journal.c @@ -844,10 +844,12 @@ int ubifs_jnl_write_inode(struct ubifs_info *c, con= st struct inode *inode) struct ubifs_ino_node *ino, *ino_start; struct ubifs_inode *ui =3D ubifs_inode(inode); int sync =3D 0, write_len =3D 0, ilen =3D UBIFS_INO_NODE_SZ; - int last_reference =3D !inode->i_nlink; + int last_reference =3D !inode->i_nlink, xattr_inos_written =3D 0; int kill_xattrs =3D ui->xattr_cnt && last_reference; u8 hash[UBIFS_HASH_ARR_SZ]; =20 + ubifs_assert(c, !ui->xattr); + dbg_jnl("ino %lu, nlink %u", inode->i_ino, inode->i_nlink); =20 /* @@ -917,12 +919,14 @@ int ubifs_jnl_write_inode(struct ubifs_info *c, con= st struct inode *inode) pack_inode(c, ino, xino, 0); ino =3D (void *)ino + UBIFS_INO_NODE_SZ; iput(xino); + xattr_inos_written++; =20 kfree(pxent); pxent =3D xent; key_read(c, &xent->key, &key); } kfree(pxent); + ubifs_assert(c, xattr_inos_written =3D=3D ui->xattr_cnt); } =20 pack_inode(c, ino, inode, 1); --=20 2.26.2