Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp794065pxb; Tue, 3 Nov 2020 12:42:34 -0800 (PST) X-Google-Smtp-Source: ABdhPJxV9ODG4xmaJ5OZqXhQLEQmFdTMChl2iE6FaEYE3Ae38Ac0u7wpO2W2PoX4AmpwIiDJuIez X-Received: by 2002:a50:fe98:: with SMTP id d24mr23302765edt.223.1604436154200; Tue, 03 Nov 2020 12:42:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604436154; cv=none; d=google.com; s=arc-20160816; b=U2y39/kFKCZ7E7xSfiSvk1W58J3+Vui8PbLHoCxeL50px8nddFXdqAvAB/8fwlZw8P AiWjMJ19/AzqAHrdnxjTAGNt5RAhc22LrGmyKTxHEv5HbcBK9h4XXbCJSArNE3IoZYZX NCgpA7QEk5zGa6/+XZ9Ed4OH+1ZtLrry8gk2BTcCcBGXkzuGhUqLHblzD9ljdzlk+iTt A8e/4Pgb6Vv8W67VUo3eUcxIPWkFP1REBUDXd+VgPv1ZJLx6X9RXYxJyvIaq4/eyShij ylolDvt7JGhZpmKkZ5QaauRltVVt2YNvUvBHpatcoo9ByMvWifMRWYGPxvmhBC2kSiRK Q/ig== 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=+0VZolhQttD/M44LmSIXGxjABR4ccvQW1iZu0OgKbQk=; b=GKM/0P0XoNi2p2npwG9ZpLD4ObIgs+e2zDg0QHC7UnhsfUOuzq1p0UteBWpmJbt1ip r3CCX+kESse0LEuNavS0xIMgOHpCY39zv+k6wL2srI9Z5TMvkBwuboVcJr1WXUMZHn+f Y5ZukA0xLYPAHoQ9x0HAsNHuVsECI5xeBGmcy8GkzAumpy7to8B+XYkur0EaXqAa7ijV 0lJ7GMsC8N+MBK8T0aPsX1pr3qK+JJ8peteqwZbXE65NqvDkP5skm+hGKH1Qj0MR+jvO 0ufiCxu43Kss4gh/fyv6SBkdtXEOM0/myKXPPVBhFRfpbrIF+sfmZW5ldt2Ddc5gAxAW MMgA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=2LKwvlZ9; 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=fail (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 q23si7085630ejs.570.2020.11.03.12.42.11; Tue, 03 Nov 2020 12:42:34 -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=@kernel.org header.s=default header.b=2LKwvlZ9; 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=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730107AbgKCUjv (ORCPT + 99 others); Tue, 3 Nov 2020 15:39:51 -0500 Received: from mail.kernel.org ([198.145.29.99]:50798 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730024AbgKCUjp (ORCPT ); Tue, 3 Nov 2020 15:39:45 -0500 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (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 0532D22277; Tue, 3 Nov 2020 20:39:44 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1604435985; bh=E+x6guri/hiPBc4xGiszrgudeK8ZhSQMuy/w+UFZ6+I=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=2LKwvlZ9nlm8ghpGhXGtTuGk5cvfekjXm2jmFSivBLuzaZ1pGbIuuQ4dQOf17dgCe d1K7YXhJj9xeWWhGzE3YkZFBOZQMbOHuyLqXzR1utWtwUGREGg8GUOUTQuztL/h0TZ Ra6guSNCV6px6fNKBIw0NlriTHS98Pfu358qtSO8= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Chao Yu , Jaegeuk Kim , Sasha Levin Subject: [PATCH 5.9 052/391] f2fs: do sanity check on zoned block device path Date: Tue, 3 Nov 2020 21:31:43 +0100 Message-Id: <20201103203350.997549109@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201103203348.153465465@linuxfoundation.org> References: <20201103203348.153465465@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 [ Upstream commit 07eb1d699452de04e9d389ff17fb8fc9e975d7bf ] sbi->devs would be initialized only if image enables multiple device feature or blkzoned feature, if blkzoned feature flag was set by fuzz in non-blkzoned device, we will suffer below panic: get_zone_idx fs/f2fs/segment.c:4892 [inline] f2fs_usable_zone_blks_in_seg fs/f2fs/segment.c:4943 [inline] f2fs_usable_blks_in_seg+0x39b/0xa00 fs/f2fs/segment.c:4999 Call Trace: check_block_count+0x69/0x4e0 fs/f2fs/segment.h:704 build_sit_entries fs/f2fs/segment.c:4403 [inline] f2fs_build_segment_manager+0x51da/0xa370 fs/f2fs/segment.c:5100 f2fs_fill_super+0x3880/0x6ff0 fs/f2fs/super.c:3684 mount_bdev+0x32e/0x3f0 fs/super.c:1417 legacy_get_tree+0x105/0x220 fs/fs_context.c:592 vfs_get_tree+0x89/0x2f0 fs/super.c:1547 do_new_mount fs/namespace.c:2896 [inline] path_mount+0x12ae/0x1e70 fs/namespace.c:3216 do_mount fs/namespace.c:3229 [inline] __do_sys_mount fs/namespace.c:3437 [inline] __se_sys_mount fs/namespace.c:3414 [inline] __x64_sys_mount+0x27f/0x300 fs/namespace.c:3414 do_syscall_64+0x2d/0x70 arch/x86/entry/common.c:46 Add sanity check to inconsistency on factors: blkzoned flag, device path and device character to avoid above panic. Signed-off-by: Chao Yu Signed-off-by: Jaegeuk Kim Signed-off-by: Sasha Levin --- fs/f2fs/super.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/fs/f2fs/super.c b/fs/f2fs/super.c index dfa072fa80815..be5050292caa5 100644 --- a/fs/f2fs/super.c +++ b/fs/f2fs/super.c @@ -2832,6 +2832,12 @@ static int sanity_check_raw_super(struct f2fs_sb_info *sbi, segment_count, dev_seg_count); return -EFSCORRUPTED; } + } else { + if (__F2FS_HAS_FEATURE(raw_super, F2FS_FEATURE_BLKZONED) && + !bdev_is_zoned(sbi->sb->s_bdev)) { + f2fs_info(sbi, "Zoned block device path is missing"); + return -EFSCORRUPTED; + } } if (secs_per_zone > total_sections || !secs_per_zone) { -- 2.27.0