Received: by 2002:ab2:710b:0:b0:1ef:a325:1205 with SMTP id z11csp1870508lql; Wed, 13 Mar 2024 10:18:07 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVjAdRXlF3T03NInmVY98vr1usIg1uzFNzRZ4iujwGvpEg4u4UXZg34rOg64YlN+WtOP0kAu6b+E9oVVq5EAFmmUCNj0+8do4Cw9HX7xQ== X-Google-Smtp-Source: AGHT+IF9w/CW7m93pNF0SZGXea9+SXZ7iI2whQ/xlExLan1YCIRlH889yZ+Nqsc0dH8/u2EgvDmD X-Received: by 2002:a05:6e02:1a8d:b0:366:7b23:7623 with SMTP id k13-20020a056e021a8d00b003667b237623mr773810ilv.10.1710350287007; Wed, 13 Mar 2024 10:18:07 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1710350286; cv=pass; d=google.com; s=arc-20160816; b=VOOPJ1HYzpfDzL3cVk0UbUOof6N4Eszt6YReH+8x4VIQxYB6L1EKIyDv0E0JwQOk49 6tdVBBn1gAd2GJV7ECcr5FV7meAO2MXZ36lG/D2UIYAXgtu8yOIntuuPIPtaN+Ice7s/ gtjyIzMCBVGVH4Iggt7gSuX/RpdTvLK2NuaOvM384dD+nJ8zZ1DXUogCkwl+byLiht5x zcXHGVlEJcVtakXFGKT1oHPwURHa6/vbCb7WxxAaZUEn4CyREPhXFLEl9WzDTyExMnvu 7GHa6SnqxcCKnRrOhYkhhTjZ+ChJxIYmYRAs2JewrEGxqczQ8NpwqUt3SLycQ2v9wpzM 7w1A== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=w9rbUtGgNGDvXslml94XX68j77x5l0xCpxZjZqFi74A=; fh=8BCRhSjjitfkgvC2+9aeZGi+53AP2zOCkXMCsmUKX8U=; b=VafPe11lAmtCFRuLKVDM+wOz/2trUE+tfKhsTHqA+g/QjXp8pP2akMgq+NVo+mSeGt A2aGvKjcCRSQZKy/PLgmKaRTdMbqS/VYcLQ5awWQp9TouzZ7kb5oX61aqrWC3x16x+u1 rgHROGse94evT9wF6sr0moNVxs9PFlLp5GRcO+KNX4NqvNlil7tfL3uF8npGoYobMguV uRr8P4AM3wf8UP/UuNHrh6e4Bgx9obfXil8lLyEBwOGjMk5boMJzIGVhUtSQ8iXxOC1G mddz+ilA/6k5qD8JE6/w450Z7z1K+EpFP3dVriGv4KqU++NVMElXvJVnyT+FfhBU1ZjW tFvA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=W6WgFEQG; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-101885-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-101885-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [147.75.48.161]) by mx.google.com with ESMTPS id d15-20020a63d64f000000b005e42b4c0c48si9532105pgj.390.2024.03.13.10.18.06 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 13 Mar 2024 10:18:06 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-101885-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) client-ip=147.75.48.161; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=W6WgFEQG; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-101885-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-101885-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id 55571B25088 for ; Wed, 13 Mar 2024 17:07:53 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 5E30D78B73; Wed, 13 Mar 2024 16:40:21 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="W6WgFEQG" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 7FE347A137; Wed, 13 Mar 2024 16:40:20 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710348020; cv=none; b=tNNtxO3G+O+lnf1VJMYg0BJmbV9EKsyh2KqF+UWL6mqA43kn6SvH8caMLhhSHIwJN2+sDoyxG0KM9KBZBHffM6r4aVW9/qbGr2xYxYEj81XluBDmnIIxGEZFLgkTIyul/5vWggGufMNd19xzklMqgmzb8N6RyFOAWggkX2N31ho= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710348020; c=relaxed/simple; bh=3UekCyyDHThKiG9v+4KxnUS74Ovcmcs7JvlE63gLlaQ=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=lR2GXls3qy0ZgFNppEyIMp14Wt/7dn5g2aO+S6RgaK5oWURVFfsLtAoUKodUXzY4BjHtbucAGhlBRgvMEi3ZPQCyBsYJhxaR5oZf9QTr2pER3ekyn2a4W6UvYfrd4tMGAbly+kuiOJXPAiITLeFAYlxLV2K2t94+ZWksHNWVkEk= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=W6WgFEQG; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id ACD3EC43394; Wed, 13 Mar 2024 16:40:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1710348020; bh=3UekCyyDHThKiG9v+4KxnUS74Ovcmcs7JvlE63gLlaQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=W6WgFEQGhA6jLvP0ldvrH7ilz5s8/3wnUE6l1jW5HCYTPTwp0m9qsILytAmJ/BJ7S Auoxy31X9R8MAABfOVokKk5p8lA8IuuXHOj79Z1EkZ3Pfpurgq1iE/NlG3Pppkg8Z+ 5dtApWZ/iZIgeJmTMI0A8lotjeW4JfURfuwU8LGXfw7KAuQNQ/qNX7fxAuA8vgQjhT C53irg534iCnI4Cv2oijLyZ6pjnAZ3CWDkx4FZE3WzIlNXdqVHEdkX98FhlWuzdH7Y rVZIcjCJF0aTd//KFAGqWBp8NJSwv3m2UbJ4Xnp45/ris4xD++zm9/MYd9HiaP1tah 5Y86k0t8zWwcg== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Lena Wang , Pablo Neira Ayuso , Sasha Levin Subject: [PATCH 6.1 17/71] netfilter: nf_conntrack_h323: Add protection for bmp length out of range Date: Wed, 13 Mar 2024 12:39:03 -0400 Message-ID: <20240313163957.615276-18-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240313163957.615276-1-sashal@kernel.org> References: <20240313163957.615276-1-sashal@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-KernelTest-Patch: http://kernel.org/pub/linux/kernel/v6.x/stable-review/patch-6.1.82-rc1.gz X-KernelTest-Tree: git://git.kernel.org/pub/scm/linux/kernel/git/stable/linux-stable-rc.git X-KernelTest-Branch: linux-6.1.y X-KernelTest-Patches: git://git.kernel.org/pub/scm/linux/kernel/git/stable/stable-queue.git X-KernelTest-Version: 6.1.82-rc1 X-KernelTest-Deadline: 2024-03-15T16:39+00:00 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit From: Lena Wang [ Upstream commit 767146637efc528b5e3d31297df115e85a2fd362 ] UBSAN load reports an exception of BRK#5515 SHIFT_ISSUE:Bitwise shifts that are out of bounds for their data type. vmlinux get_bitmap(b=75) + 712 vmlinux decode_seq(bs=0xFFFFFFD008037000, f=0xFFFFFFD008037018, level=134443100) + 1956 vmlinux decode_choice(base=0xFFFFFFD0080370F0, level=23843636) + 1216 vmlinux decode_seq(f=0xFFFFFFD0080371A8, level=134443500) + 812 vmlinux decode_choice(base=0xFFFFFFD008037280, level=0) + 1216 vmlinux DecodeRasMessage() + 304 vmlinux ras_help() + 684 vmlinux nf_confirm() + 188 Due to abnormal data in skb->data, the extension bitmap length exceeds 32 when decoding ras message then uses the length to make a shift operation. It will change into negative after several loop. UBSAN load could detect a negative shift as an undefined behaviour and reports exception. So we add the protection to avoid the length exceeding 32. Or else it will return out of range error and stop decoding. Fixes: 5e35941d9901 ("[NETFILTER]: Add H.323 conntrack/NAT helper") Signed-off-by: Lena Wang Signed-off-by: Pablo Neira Ayuso Signed-off-by: Sasha Levin --- net/netfilter/nf_conntrack_h323_asn1.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/net/netfilter/nf_conntrack_h323_asn1.c b/net/netfilter/nf_conntrack_h323_asn1.c index e697a824b0018..540d97715bd23 100644 --- a/net/netfilter/nf_conntrack_h323_asn1.c +++ b/net/netfilter/nf_conntrack_h323_asn1.c @@ -533,6 +533,8 @@ static int decode_seq(struct bitstr *bs, const struct field_t *f, /* Get fields bitmap */ if (nf_h323_error_boundary(bs, 0, f->sz)) return H323_ERROR_BOUND; + if (f->sz > 32) + return H323_ERROR_RANGE; bmp = get_bitmap(bs, f->sz); if (base) *(unsigned int *)base = bmp; @@ -589,6 +591,8 @@ static int decode_seq(struct bitstr *bs, const struct field_t *f, bmp2_len = get_bits(bs, 7) + 1; if (nf_h323_error_boundary(bs, 0, bmp2_len)) return H323_ERROR_BOUND; + if (bmp2_len > 32) + return H323_ERROR_RANGE; bmp2 = get_bitmap(bs, bmp2_len); bmp |= bmp2 >> f->sz; if (base) -- 2.43.0