Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3691121pxb; Mon, 24 Jan 2022 15:29:21 -0800 (PST) X-Google-Smtp-Source: ABdhPJwB1sdz6mPhfW7qexofZM74wkpiX4Hy0vwOOqKHGk3ut0/4/G5qNO0HJUcQ5xPcG/6dFf+k X-Received: by 2002:a63:7210:: with SMTP id n16mr13434288pgc.527.1643066961337; Mon, 24 Jan 2022 15:29:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643066961; cv=none; d=google.com; s=arc-20160816; b=RT0UW3LDwqdpgLRkrl4ELheboGHDko9YncuuxTD7e7Ehh54oNqbd8/J5zZHHZt0JNF o8XgGpw8/RGlr/At3h1irPB0DtCEHQO1Kd1PM6E1kgGOutvll2QV53frTWG4DWNB6o8k 8XVSCmdKSdAB5/94hFVcFJfYjyZEwlEVMOj6pO8W+jQMENWhF9VulOkJvbPRqDdVMqyx 2L/lGFDX73b9eS8/dYb42649uxxyYfZ/zSfa/MqjBUYcrmBQarlFC66niDYN/WjzRDLo ZnD+T9BADaYULUW6SyGUEme433tYSGXeCjZ6c+N3BPOfAfUYu8WM4d0rDHsOx6pzO5gZ C2Cg== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=bNBW0Bb7HDFD5CqOYdp1+hbwfjsTpx1NMfuArO5yC7A=; b=PMDm2u/x36yB7qtfmKpQQVRShvCfpsESKjALYUD1K6I+h8lplylD4hdjKImaf0nzDU Fc+2CnLeyq7SzY6k/15JS6UvlzFnjS8Es4uQRZJ7QC4p4gVeljwkjOb5TgW8tcDOPNQJ 8XW751uk5P6f5TeNhWsMOaaowI1uMrLV/Vv2UNiLQzNJwwCyJKID4NT/cyxtf3VBwK2q 1ctnH9fGxuvyUqZzfVjmkMJBcCeTEmrksQ6mRmWiozaovg9j4x8oKhTdg7gxkJkGX8X8 N+ifuNNXLN1IEED3hJ96ebbUFaGbwZnxO9rHPUMtPHj56w3/oWD8Q+bYG+J7yGyUWkss K4Xw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=JXmLUO7t; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b5si14471483plz.335.2022.01.24.15.29.07; Mon, 24 Jan 2022 15:29:21 -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; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=JXmLUO7t; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1849284AbiAXXZV (ORCPT + 99 others); Mon, 24 Jan 2022 18:25:21 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39062 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1587755AbiAXW3h (ORCPT ); Mon, 24 Jan 2022 17:29:37 -0500 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A699FC095410; Mon, 24 Jan 2022 12:55:18 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 5D196B811FB; Mon, 24 Jan 2022 20:55:17 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 07D9CC340E5; Mon, 24 Jan 2022 20:55:14 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643057716; bh=IgHUHKKQzYCKAcKqsjwDkEbLcCrTpp0xgZ/idz6puKc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=JXmLUO7tcuEqok3wReiCViXl0hkF4tlIKJBjOdoDTgmyNpiAa18fW+fmJ8oz2hLqX ZJG59v3pNJC3IbYApdni3w1B6nC8j9mJMbNugezCKEnR/MhiWR5ovDUZlNNY1myabb vV1tecXB7BfK8J+pfkYv1LrNyWZ/mgvQ1/ciOrfs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Wenqing Liu , Chao Yu , Jaegeuk Kim Subject: [PATCH 5.16 0012/1039] f2fs: fix to do sanity check on last xattr entry in __f2fs_setxattr() Date: Mon, 24 Jan 2022 19:30:01 +0100 Message-Id: <20220124184125.560804776@linuxfoundation.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124184125.121143506@linuxfoundation.org> References: <20220124184125.121143506@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Chao Yu commit 645a3c40ca3d40cc32b4b5972bf2620f2eb5dba6 upstream. As Wenqing Liu reported in bugzilla: https://bugzilla.kernel.org/show_bug.cgi?id=215235 - Overview page fault in f2fs_setxattr() when mount and operate on corrupted image - Reproduce tested on kernel 5.16-rc3, 5.15.X under root 1. unzip tmp7.zip 2. ./single.sh f2fs 7 Sometimes need to run the script several times - Kernel dump loop0: detected capacity change from 0 to 131072 F2FS-fs (loop0): Found nat_bits in checkpoint F2FS-fs (loop0): Mounted with checkpoint version = 7548c2ee BUG: unable to handle page fault for address: ffffe47bc7123f48 RIP: 0010:kfree+0x66/0x320 Call Trace: __f2fs_setxattr+0x2aa/0xc00 [f2fs] f2fs_setxattr+0xfa/0x480 [f2fs] __f2fs_set_acl+0x19b/0x330 [f2fs] __vfs_removexattr+0x52/0x70 __vfs_removexattr_locked+0xb1/0x140 vfs_removexattr+0x56/0x100 removexattr+0x57/0x80 path_removexattr+0xa3/0xc0 __x64_sys_removexattr+0x17/0x20 do_syscall_64+0x37/0xb0 entry_SYSCALL_64_after_hwframe+0x44/0xae The root cause is in __f2fs_setxattr(), we missed to do sanity check on last xattr entry, result in out-of-bound memory access during updating inconsistent xattr data of target inode. After the fix, it can detect such xattr inconsistency as below: F2FS-fs (loop11): inode (7) has invalid last xattr entry, entry_size: 60676 F2FS-fs (loop11): inode (8) has corrupted xattr F2FS-fs (loop11): inode (8) has corrupted xattr F2FS-fs (loop11): inode (8) has invalid last xattr entry, entry_size: 47736 Cc: stable@vger.kernel.org Reported-by: Wenqing Liu Signed-off-by: Chao Yu Signed-off-by: Jaegeuk Kim Signed-off-by: Greg Kroah-Hartman --- fs/f2fs/xattr.c | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) --- a/fs/f2fs/xattr.c +++ b/fs/f2fs/xattr.c @@ -684,8 +684,17 @@ static int __f2fs_setxattr(struct inode } last = here; - while (!IS_XATTR_LAST_ENTRY(last)) + while (!IS_XATTR_LAST_ENTRY(last)) { + if ((void *)(last) + sizeof(__u32) > last_base_addr || + (void *)XATTR_NEXT_ENTRY(last) > last_base_addr) { + f2fs_err(F2FS_I_SB(inode), "inode (%lu) has invalid last xattr entry, entry_size: %zu", + inode->i_ino, ENTRY_SIZE(last)); + set_sbi_flag(F2FS_I_SB(inode), SBI_NEED_FSCK); + error = -EFSCORRUPTED; + goto exit; + } last = XATTR_NEXT_ENTRY(last); + } newsize = XATTR_ALIGN(sizeof(struct f2fs_xattr_entry) + len + size);