Received: by 2002:ab2:710b:0:b0:1ef:a325:1205 with SMTP id z11csp1905650lql; Wed, 13 Mar 2024 11:23:52 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCXg3kGBOymQrg7Z64eCCZ6LUbYo5gRz/75iU2RsJWfWGPAuoGy9dM61QJaVP+7aqaUbjqMi4erLltRBr+g24QosyesJo80HT+CAIwcXVA== X-Google-Smtp-Source: AGHT+IFy5a3HPilknPEsyDBdPgHrS7gmNX6lTBEMwK6ZQGcDJFRE9gXiRpnG63G+pD/L0+pX1JtM X-Received: by 2002:a17:902:e54f:b0:1db:e7a4:90a8 with SMTP id n15-20020a170902e54f00b001dbe7a490a8mr11668783plf.10.1710354231895; Wed, 13 Mar 2024 11:23:51 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1710354231; cv=pass; d=google.com; s=arc-20160816; b=kx6ESki4lPy2VK2MZLkhZny9IjVWjfcHF4PD4Oj4mOnX/zv/2mHkyhCVdZqJFTSTba MA/Hf8aS6ijVrahqkkCfevPYNMUTjhrpgaYOYv4YKDU8wiiOFD4vuDSBp4ByIT6nPytL PMd375WLUgpRvbF6PWGZqg2baa7eJmd/KVumqPrJwq3kp5NR7NRgyl9gIoh5hZa9vCvW 4DCmnyQ3Oqj6yTyd+os0zAG5aWnqP3RyvmJxtA+OfqDypJPcsuswc/Hg2bjrv1ib+fbe vhtCDcPmtYklB3vLoiTRcuWTNkCbFLlQYK0EkZa3mup8RLxgE1rzhY0v2JTe9A/0eEw5 mcdQ== 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=kKIXe3IvZFxUDvSjCCO58tPrGdEk2K8lFiHxsdtaFNk=; fh=8BCRhSjjitfkgvC2+9aeZGi+53AP2zOCkXMCsmUKX8U=; b=TOGb7iHV5oA6Ic9tXSov7CK1ltLlxrXxd6dmE4FWRXi/8+LlGmzVFKRkvsfVKszbta qIYNckS8B/STXP2uyOErQZwihn6I37N7X2pBUiHahcR28rAnNUsv062Y25JSUwD9peuI Q4zxD4smb5WOVsKt6/qbOPhfzXDhDOvVyM1FV6LanMz6k21WGbtJuO3hNxx/UetPVSpe PAsV7PFKAfktHWhZC04pSix/Cjchl6I0dsfrP7WQoeW6I9NZRAwq0u0OmiTfB00jJHQQ mGDKejhBFDhZlJqXjL6pJ9IMQ7/Dou3BhIGEjUxBhvhQxQfLoARR2pumTko2GgPPnN3Q xphw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=Brg8180F; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-102132-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-102132-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. [2604:1380:40f1:3f00::1]) by mx.google.com with ESMTPS id o3-20020a170902d4c300b001ddd40bbd6asi1306156plg.25.2024.03.13.11.23.51 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 13 Mar 2024 11:23:51 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-102132-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) client-ip=2604:1380:40f1:3f00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=Brg8180F; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-102132-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-102132-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 9C902B22898 for ; Wed, 13 Mar 2024 18:06:02 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 874EF6F060; Wed, 13 Mar 2024 17:02:29 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="Brg8180F" 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 AB1AF6EB61; Wed, 13 Mar 2024 17:02:28 +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=1710349348; cv=none; b=YgSta39JqxQyV6MCeHOZEdXR4w6doK6BPZrIPEA+qWYm0jbGEfu3IBcmKHwyE2CWH9qEifBWN8Vqoh6/B+SzHCjvYl0vZHuOu29Cwj54DB8uAjai/nDaZReuw+jZrDIR60F6fBH2ZhRrKEstfZ3VwegVcuc6HZCV0WntCtgFRLk= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710349348; c=relaxed/simple; bh=/clY8IOCZe3Fgk2Y1+bMZg7/zXp+EmfAKKhk+/ItJIE=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=jqUxGBAJmDQi6c1jYxKMdEDpuJyFW/CE7sGUtI6w3QovSOV4KZTD0JPg0OXKVCjWlDdJ9I/pjt6d2tmgp5W31joJUXWLdHA0HCQLPTf7DadKWNN1z43+acZaK+7kymS6att1fuG7hRtBk/KrhUY/rgijSXLMbad9jmGuD5DAsC8= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=Brg8180F; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id DB7C1C433B2; Wed, 13 Mar 2024 17:02:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1710349348; bh=/clY8IOCZe3Fgk2Y1+bMZg7/zXp+EmfAKKhk+/ItJIE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Brg8180F4dzMkJyrPL5eYF2Dwk0NrrJIwzfBvx7QD0aYkzgCiG5HbFcpShUFuoamq 6RR1FCk3C2EWk8skpahuLh9U1ARexdDkluUqQZ3pVms9v44HcESiknE1w6OlsOKHZI b+u6KYOauRKVI7YmED22MlOfNY5OaPnWdKekWhdYVYhUUVu26XwfG+gv3RHIkEsLqv vDhW+KcCSFExBDnkJGO35d2eegtQ0fPpgX8EZtz2dzFx27HXqfERUyEAqWK+I2XGXL tHE53USHFCKJUNad+987Mx5v4UHhsAozoArIXMwnizmT1q+fMUe2VyRDfulld0g8HG qb637ETBlpqzQ== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Lena Wang , Pablo Neira Ayuso , Sasha Levin Subject: [PATCH 5.4 12/51] netfilter: nf_conntrack_h323: Add protection for bmp length out of range Date: Wed, 13 Mar 2024 13:01:33 -0400 Message-ID: <20240313170212.616443-13-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240313170212.616443-1-sashal@kernel.org> References: <20240313170212.616443-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/v5.x/stable-review/patch-5.4.272-rc1.gz X-KernelTest-Tree: git://git.kernel.org/pub/scm/linux/kernel/git/stable/linux-stable-rc.git X-KernelTest-Branch: linux-5.4.y X-KernelTest-Patches: git://git.kernel.org/pub/scm/linux/kernel/git/stable/stable-queue.git X-KernelTest-Version: 5.4.272-rc1 X-KernelTest-Deadline: 2024-03-15T17:02+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 573cb44814813..814857ae3b812 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