From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 715FAC4332F for ; Tue, 20 Dec 2022 01:22:16 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id EADBA8E0002; Mon, 19 Dec 2022 20:22:15 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id E5DE28E0001; Mon, 19 Dec 2022 20:22:15 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id D260D8E0002; Mon, 19 Dec 2022 20:22:15 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0013.hostedemail.com [216.40.44.13]) by kanga.kvack.org (Postfix) with ESMTP id C294D8E0001 for ; Mon, 19 Dec 2022 20:22:15 -0500 (EST) Received: from smtpin04.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay05.hostedemail.com (Postfix) with ESMTP id 9E2754094E for ; Tue, 20 Dec 2022 01:22:15 +0000 (UTC) X-FDA: 80260933830.04.33BF856 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by imf15.hostedemail.com (Postfix) with ESMTP id EA742A000A for ; Tue, 20 Dec 2022 01:22:13 +0000 (UTC) Authentication-Results: imf15.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=UEdaG28P; spf=pass (imf15.hostedemail.com: domain of sashal@kernel.org designates 139.178.84.217 as permitted sender) smtp.mailfrom=sashal@kernel.org; dmarc=pass (policy=none) header.from=kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1671499334; a=rsa-sha256; cv=none; b=W9bGMVpxNnsd7G2vu4na9TCD1LeBagAo/aqARDxrVnBYzq3d2zwRc3bBwPK/5ffBLCBtOz S3C3tqckr/89lONYZ7NCEKH58c2LGy7c+4CqqtbGBgUupYASKtiKXR7mLTaEzEEe6v6fX1 rczYf2l1yZ3GrnBlbNAWyaI/55gPalY= ARC-Authentication-Results: i=1; imf15.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=UEdaG28P; spf=pass (imf15.hostedemail.com: domain of sashal@kernel.org designates 139.178.84.217 as permitted sender) smtp.mailfrom=sashal@kernel.org; dmarc=pass (policy=none) header.from=kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1671499334; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=PkWTt2rYoiytfAyae4jzIswD9FZmjkUqHaqLb3kCvW8=; b=5dEmjaCyvaRKUWCGkP/jEZYIxE4fHa/EDNWKXHXjZs1CncUZ1YCyuiAwxwC03Z1moEyGcM I9SjcTpxSZGMnwRXdhdbCniTgFKfKBCN73+ggCAFbnDzYFhGSkyEOI3+xGHsCy9sdmbRAU TmZfi9GFYQHMlxdKmNozG7pyqIeUtf8= 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 dfw.source.kernel.org (Postfix) with ESMTPS id 1DEF661118; Tue, 20 Dec 2022 01:22:13 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 670EDC433F1; Tue, 20 Dec 2022 01:22:11 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1671499332; bh=aQFaecaqcH30nHzpU+8RbcjuDn2x7otmuRN7p6ZP31U=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=UEdaG28PR9Ggzi62AGfzP82yi4L577sT4Sywz9kPTvV7nWZlkOD0boZWWbSJdRi3a NhA2zOYwmMNAqJGKo1Rvsy5qfQSAfPi4uyeC7WNHiH02vgQCH3vuZVLf5ut/1kbru/ 5PxMpKzbJkl1lQzwYr0OJVjf040ssqiF3kE2wDzv6pnLJ+efLEVXmd1YaBP82FEYjc 7Q4u+EfAETGE+W+Y0aaBw4hqQI2IJctttAbuFISzv0AEWsOGUopuwQepqqNnDT+USK VqL2A0XEzAxzlP31MyTPnVCLF4OKHw04xFldaOGpaeya6ImRBA7xEhOb0DqzltJsJo OCbBPjCtVYnDQ== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Hawkins Jiawei , syzbot+a3e6acd85ded5c16a709@syzkaller.appspotmail.com, Mike Kravetz , Muchun Song , Ian Kent , Andrew Morton , Sasha Levin , muchun.song@linux.dev, linux-mm@kvack.org Subject: [PATCH AUTOSEL 5.15 5/9] hugetlbfs: fix null-ptr-deref in hugetlbfs_parse_param() Date: Mon, 19 Dec 2022 20:21:55 -0500 Message-Id: <20221220012159.1222517-5-sashal@kernel.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20221220012159.1222517-1-sashal@kernel.org> References: <20221220012159.1222517-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit X-Rspam-User: X-Rspamd-Queue-Id: EA742A000A X-Rspamd-Server: rspam01 X-Stat-Signature: 58wshqz9aneeiuzud7ujctp1gynwwag6 X-HE-Tag: 1671499333-860262 X-HE-Meta: U2FsdGVkX18qK+clQ/1xKtibSeuw+u8m5cQshDraFAKEbNmvPkIHNZMpj3WWprHx6j9i+p1augOXYRdwFQg8LcCYEVHCUuekhWA38b0TkpB9iTys5Dt41F9dIv6VzIEFa+nu4zA4pMoE0lPJitut0mE2oT6DxDQfeoxzcPML7ZDHL2ZRk6MQ59PEfLzpLe25f8D4iNXIdhIuS7HsjXrizpXnEJ/y4EoovjmeQK95/4+P+vHYbrbnItyFQORaicIWOpFFyNy+ARUsUMyyEjTgUCeIxXwYYS6D++uqo3lbU+abhKk+JAQ3CgEv43geJv+5rVrdzA3icLyJ9Vr81aK2pjjXssAQEqW9LE5gu2jbWO+VbJZrkqYDCutRaN8ZM2TXEKDcM3J/QUDfms92rWK5MNfaXjrllZWxncNqvz2nU1eH5SIYYlMES+aK/rz/limfEH+wK9iDH6/yQGAekOOZvd4B9/seRg8jzi5fuSeNVZMf4TouHLfALm+FCwKK61QrboOSshMP/zl5IlV90TxMZgz3oHD0fW/PyAYO4gM1FONk+sB4D4YWqneWkPByPlCLlQXWLLkRyA7O+jk2GogHbDOIJM4bGTts79UG+ftCIbQCDoV+dG3H7fTjDkP6UlK5oZrC53K7RnFR2axHxd/OkB0wyxcMWCNoK/fafn64ERLToLyNT8IhbIt5X3zTtwsorGhVxG7SNneGV14CbrkEMIeSU1go0lVDnTKIE5kOzmgyRASkDa9VI2azXiOoKes8HRVZ6jpbk2AceeePpEbL4OUT5W1WpvgI/dibMboUy2y9uMEgH3/wxjxclqZII4iknOciwABt+VHiJ7ULs4Os1F6vcBEOcRGp9Oskze0QUjcnp222ViG2CEcXa9/q0tnkkcq0t2w2Tj6WGtfCE4SfGGE0YfDRckpPVdvxINk8lF1qq23I/nOSI56U1SO3s7g9aFYTs7XzPtQN1ZE82S7 ohuciYvd yiewCQvpB+445/9CRU+D9f5AazE0YxxJBU9cw7dDdKmDVLcGXyklFy4de64wjnd1df2AUHUIHCOduMpVUoOacDqpsR/Lmqf7lC69OYmGH72QtYsXeJuOor15YpH9D23bV93glG2rNagGDMaPeC2zU0ScKZEqdYIRgNVSG85XfLPLm8V5tG1W/kWplcmIjRKAUV1cmjOGQ2yeyWPVUeIhDJWwSag== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: From: Hawkins Jiawei [ Upstream commit 26215b7ee923b9251f7bb12c4e5f09dc465d35f2 ] Syzkaller reports a null-ptr-deref bug as follows: ====================================================== KASAN: null-ptr-deref in range [0x0000000000000000-0x0000000000000007] RIP: 0010:hugetlbfs_parse_param+0x1dd/0x8e0 fs/hugetlbfs/inode.c:1380 [...] Call Trace: vfs_parse_fs_param fs/fs_context.c:148 [inline] vfs_parse_fs_param+0x1f9/0x3c0 fs/fs_context.c:129 vfs_parse_fs_string+0xdb/0x170 fs/fs_context.c:191 generic_parse_monolithic+0x16f/0x1f0 fs/fs_context.c:231 do_new_mount fs/namespace.c:3036 [inline] path_mount+0x12de/0x1e20 fs/namespace.c:3370 do_mount fs/namespace.c:3383 [inline] __do_sys_mount fs/namespace.c:3591 [inline] __se_sys_mount fs/namespace.c:3568 [inline] __x64_sys_mount+0x27f/0x300 fs/namespace.c:3568 do_syscall_x64 arch/x86/entry/common.c:50 [inline] do_syscall_64+0x35/0xb0 arch/x86/entry/common.c:80 entry_SYSCALL_64_after_hwframe+0x63/0xcd [...] ====================================================== According to commit "vfs: parse: deal with zero length string value", kernel will set the param->string to null pointer in vfs_parse_fs_string() if fs string has zero length. Yet the problem is that, hugetlbfs_parse_param() will dereference the param->string, without checking whether it is a null pointer. To be more specific, if hugetlbfs_parse_param() parses an illegal mount parameter, such as "size=,", kernel will constructs struct fs_parameter with null pointer in vfs_parse_fs_string(), then passes this struct fs_parameter to hugetlbfs_parse_param(), which triggers the above null-ptr-deref bug. This patch solves it by adding sanity check on param->string in hugetlbfs_parse_param(). Link: https://lkml.kernel.org/r/20221020231609.4810-1-yin31149@gmail.com Reported-by: syzbot+a3e6acd85ded5c16a709@syzkaller.appspotmail.com Tested-by: syzbot+a3e6acd85ded5c16a709@syzkaller.appspotmail.com Link: https://lore.kernel.org/all/0000000000005ad00405eb7148c6@google.com/ Signed-off-by: Hawkins Jiawei Reviewed-by: Mike Kravetz Cc: Hawkins Jiawei Cc: Muchun Song Cc: Ian Kent Signed-off-by: Andrew Morton Signed-off-by: Sasha Levin --- fs/hugetlbfs/inode.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/fs/hugetlbfs/inode.c b/fs/hugetlbfs/inode.c index be8deec29ebe..352230a011e0 100644 --- a/fs/hugetlbfs/inode.c +++ b/fs/hugetlbfs/inode.c @@ -1250,7 +1250,7 @@ static int hugetlbfs_parse_param(struct fs_context *fc, struct fs_parameter *par case Opt_size: /* memparse() will accept a K/M/G without a digit */ - if (!isdigit(param->string[0])) + if (!param->string || !isdigit(param->string[0])) goto bad_val; ctx->max_size_opt = memparse(param->string, &rest); ctx->max_val_type = SIZE_STD; @@ -1260,7 +1260,7 @@ static int hugetlbfs_parse_param(struct fs_context *fc, struct fs_parameter *par case Opt_nr_inodes: /* memparse() will accept a K/M/G without a digit */ - if (!isdigit(param->string[0])) + if (!param->string || !isdigit(param->string[0])) goto bad_val; ctx->nr_inodes = memparse(param->string, &rest); return 0; @@ -1276,7 +1276,7 @@ static int hugetlbfs_parse_param(struct fs_context *fc, struct fs_parameter *par case Opt_min_size: /* memparse() will accept a K/M/G without a digit */ - if (!isdigit(param->string[0])) + if (!param->string || !isdigit(param->string[0])) goto bad_val; ctx->min_size_opt = memparse(param->string, &rest); ctx->min_val_type = SIZE_STD; -- 2.35.1