Received: by 2002:a05:6512:3d0e:0:0:0:0 with SMTP id d14csp4723lfv; Tue, 12 Apr 2022 14:58:07 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyBn3YMuSRB7kA8SeDt/uVdaipE/FERzlZJx5GQNOWxYLP/NQW6LKdh5p9dqgBkLgE+n24X X-Received: by 2002:a17:90b:1643:b0:1cd:41c1:711e with SMTP id il3-20020a17090b164300b001cd41c1711emr2746076pjb.169.1649800686967; Tue, 12 Apr 2022 14:58:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649800686; cv=none; d=google.com; s=arc-20160816; b=uazCfH6ptJSq3l0XP3eKRzyf7JNMI1hC0T9Y7+nN7BQej6tS6k7ssNm1Acv984x8yM OTrB2pBRS73dGivxjCBg+kvxx7gpnO3CZqlArU+qBZBTIQjOfMv/8NGJ/TPjKJ3bBXM9 KZmgTWwAY6uM3JG7k2nnZAZhDRbruOm8lOkec2OeOZGaNIsz+VBCAw1uLCG8IW+fmeTj rLNkPKhJwtJcCmYi8pvRVZivcK3SPhlywg+6iqCSALtAe4vbfmUXW3mwO1PvE9KTcRlm TqtDg/QHka11cftfDUEc7atTqsEfPFL6jLz7/dL3Il1UtlbjEYfHoHizDJbaQDaZ9igl 3LUw== 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=Gt0PcVE0VBHv5XPTUShKjkS1qOTRPWORyDDx4rhcBds=; b=Xx/2GhGzOek+QaRTb2t9A0GPAaO/vNTHNCaDGBSJTobgGCfTAnl/wdU1mw3i8ytAeP zDbzle3ZTeSRu9xmhtO+3ssvjz9ofNOz0+cwTF1EWq0XSnp/MkntFIOJbYwSt9jHbGnX IXIvubooN82vgdQjW3zPgv0/UqXvYnYB7LOSiISJEIGSIsv3TmwJ4YwlMv7nY27Kymj4 EYhXM46/sK7qo/oEyexfgcEOTV0UhOX/bNjfrVgFf7tROSB/j7Bk73wgTtqE9zqsa6b3 1s26RgBccl7E6srBlO1u1AAVLwsi4aVSQuUxXeTSo5Q6Gx8lRE7ua1qBXnpR8h7kXxlv RMcQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=TqH6kctU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1: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 lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id bk11-20020a056a02028b00b00398d8b1871bsi3656427pgb.44.2022.04.12.14.58.06 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 12 Apr 2022 14:58:06 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=TqH6kctU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1: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: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 22506140DF8; Tue, 12 Apr 2022 13:51:06 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1351037AbiDLGwf (ORCPT + 99 others); Tue, 12 Apr 2022 02:52:35 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58028 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1350923AbiDLGsS (ORCPT ); Tue, 12 Apr 2022 02:48:18 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8936D255A2; Mon, 11 Apr 2022 23:39:23 -0700 (PDT) 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 1F106B81B4E; Tue, 12 Apr 2022 06:39:22 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 5DBADC385B8; Tue, 12 Apr 2022 06:39:20 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1649745560; bh=r7zwxBmSBYLoVuMUOCzhurkmYQox+oscdpkyavZfQGg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=TqH6kctUNbU+StCq+MMlVTNb98yVSJbcLBVBKHRUFA33bkOMzwS7Z/Qt/cBelD3qw WNkLykLsaq620wLjoylUCtXj0qqhvWVV7chtbgPycleTIrsdhmaw68OKuFEk3KqBWx jmQFR6+uBQ/4ij6MNWhNJD+KCrgOzfa+mrvp/S8I= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, syzbot+63d688f1d899c588fb71@syzkaller.appspotmail.com, Guo Xuenan , Nick Terrell , Gao Xiang , Yann Collet , Chengyang Fan , Andrew Morton , Linus Torvalds Subject: [PATCH 5.10 138/171] lz4: fix LZ4_decompress_safe_partial read out of bound Date: Tue, 12 Apr 2022 08:30:29 +0200 Message-Id: <20220412062931.880396133@linuxfoundation.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220412062927.870347203@linuxfoundation.org> References: <20220412062927.870347203@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Guo Xuenan commit eafc0a02391b7b36617b36c97c4b5d6832cf5e24 upstream. When partialDecoding, it is EOF if we've either filled the output buffer or can't proceed with reading an offset for following match. In some extreme corner cases when compressed data is suitably corrupted, UAF will occur. As reported by KASAN [1], LZ4_decompress_safe_partial may lead to read out of bound problem during decoding. lz4 upstream has fixed it [2] and this issue has been disscussed here [3] before. current decompression routine was ported from lz4 v1.8.3, bumping lib/lz4 to v1.9.+ is certainly a huge work to be done later, so, we'd better fix it first. [1] https://lore.kernel.org/all/000000000000830d1205cf7f0477@google.com/ [2] https://github.com/lz4/lz4/commit/c5d6f8a8be3927c0bec91bcc58667a6cfad244ad# [3] https://lore.kernel.org/all/CC666AE8-4CA4-4951-B6FB-A2EFDE3AC03B@fb.com/ Link: https://lkml.kernel.org/r/20211111105048.2006070-1-guoxuenan@huawei.com Reported-by: syzbot+63d688f1d899c588fb71@syzkaller.appspotmail.com Signed-off-by: Guo Xuenan Reviewed-by: Nick Terrell Acked-by: Gao Xiang Cc: Yann Collet Cc: Chengyang Fan Cc: Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Greg Kroah-Hartman --- lib/lz4/lz4_decompress.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) --- a/lib/lz4/lz4_decompress.c +++ b/lib/lz4/lz4_decompress.c @@ -271,8 +271,12 @@ static FORCE_INLINE int LZ4_decompress_g ip += length; op += length; - /* Necessarily EOF, due to parsing restrictions */ - if (!partialDecoding || (cpy == oend)) + /* Necessarily EOF when !partialDecoding. + * When partialDecoding, it is EOF if we've either + * filled the output buffer or + * can't proceed with reading an offset for following match. + */ + if (!partialDecoding || (cpy == oend) || (ip >= (iend - 2))) break; } else { /* may overwrite up to WILDCOPYLENGTH beyond cpy */