Received: by 2002:a05:6358:4e97:b0:b3:742d:4702 with SMTP id ce23csp2932796rwb; Mon, 15 Aug 2022 14:19:15 -0700 (PDT) X-Google-Smtp-Source: AA6agR5auei6+rM2ClDZCOEsi2UqZCKDIO2mvr8OPFe5JI5jF6GjYdkCEBjhsid/JsYChFym5F36 X-Received: by 2002:a05:6402:51d1:b0:43e:f2d2:fa25 with SMTP id r17-20020a05640251d100b0043ef2d2fa25mr16015446edd.31.1660598355388; Mon, 15 Aug 2022 14:19:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1660598355; cv=none; d=google.com; s=arc-20160816; b=dEhFyViaT/uw02TURhETcgP7dXSFbnHG4D7NUwom4zZHaVa0Jh0hG6Mg8AFnGU9s2k HFTcSFN/YxypI03rLBN3x3YwgXvycUgoFz6KPt1kZfA4KD9kRYYW+l3sIA4DMCM7wFeU 6rfsuzpoHWFG6o9qV97OKzPFoKnBF8wKkKfXqJjl9DTul1hA3xY/gMaDszHQZ9Yay3Ci suvnd1IQ7D3X8/k3CGybHp3iry3X4QcNbOmDtsY1EqgDe2FZi0V0+8gW0EqYk1h8m8wZ bP4xawQ7q2roviRLV81KaAzuYJxdCcRDwWMYlfQtd4VXKALCuBaixp3VOLBwyzPyU3uP /tvw== 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=pWCxXQZmG9fAvQWdc0b/c3/e4JRIZKm1EZcQiSXaoi8=; b=b8bbACOpXwovn1lViB1w02rtpOO5i/LvduK8KpIHKA5waPwDaLfEnkGdOwvkAc8D9j BVzxGeTJXJFPQBhRO6XHO00XJjdb6QONNtXE9RgLW18XKmXAQeFQSpUkHKc9Z5x0GIYa LUG9E0hUf0fSPQu5YtkH44yzNkcSx3zdYd2Sh6e3bt9da4x+2gY7PN5U+OizPLFrexeT 1a5ZIP32Bw3ETnGhJJKfLptZ1b1JIrLb9ovuqIHMDtA+UMEUQJHvEETyHkBM9MUvs7jx HN704PW8V8RUZtOEmxWEcABNtKrNDk0SS8HKft8NHH+qQiSEFCzjEBETbMsFbwN4QwfZ 56Eg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=xD7U4pbp; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id s4-20020a508d04000000b0043bc31ac7d0si7943871eds.211.2022.08.15.14.18.41; Mon, 15 Aug 2022 14:19:15 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=xD7U4pbp; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242872AbiHOUyN (ORCPT + 99 others); Mon, 15 Aug 2022 16:54:13 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44252 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1346411AbiHOUwf (ORCPT ); Mon, 15 Aug 2022 16:52:35 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 459C3BCC36; Mon, 15 Aug 2022 12:10:34 -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 dfw.source.kernel.org (Postfix) with ESMTPS id 25E5660EDA; Mon, 15 Aug 2022 19:10:30 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 12C5CC433C1; Mon, 15 Aug 2022 19:10:28 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1660590629; bh=sFF/GLrtKkldifMSHkZh0cLIrumrBiRtQIFmzUP1GiI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=xD7U4pbpHpk08CyqOrYx+iIl3WjG0bfeHxf1KJxOGkpeewiRJ6CGJcC1RxLjSZoYB 7fcBwqSq12vdI7k8cVPBWcmK9rx6yTskLv1Qun/e33MKWwzJXSeXDxqYtW0jYznWPo FwFiRq9SSqubIFTlFaCQG6xZQkM2ujkF85hD4W1c= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Alexey Kodanev , Alex Deucher , Sasha Levin Subject: [PATCH 5.18 0320/1095] drm/radeon: fix potential buffer overflow in ni_set_mc_special_registers() Date: Mon, 15 Aug 2022 19:55:19 +0200 Message-Id: <20220815180443.028776021@linuxfoundation.org> X-Mailer: git-send-email 2.37.2 In-Reply-To: <20220815180429.240518113@linuxfoundation.org> References: <20220815180429.240518113@linuxfoundation.org> User-Agent: quilt/0.67 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham 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: Alexey Kodanev [ Upstream commit 136f614931a2bb73616b292cf542da3a18daefd5 ] The last case label can write two buffers 'mc_reg_address[j]' and 'mc_data[j]' with 'j' offset equal to SMC_NISLANDS_MC_REGISTER_ARRAY_SIZE since there are no checks for this value in both case labels after the last 'j++'. Instead of changing '>' to '>=' there, add the bounds check at the start of the second 'case' (the first one already has it). Also, remove redundant last checks for 'j' index bigger than array size. The expression is always false. Moreover, before or after the patch 'table->last' can be equal to SMC_NISLANDS_MC_REGISTER_ARRAY_SIZE and it seems it can be a valid value. Detected using the static analysis tool - Svace. Fixes: 69e0b57a91ad ("drm/radeon/kms: add dpm support for cayman (v5)") Signed-off-by: Alexey Kodanev Signed-off-by: Alex Deucher Signed-off-by: Sasha Levin --- drivers/gpu/drm/radeon/ni_dpm.c | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/drivers/gpu/drm/radeon/ni_dpm.c b/drivers/gpu/drm/radeon/ni_dpm.c index 769f666335ac..672d2239293e 100644 --- a/drivers/gpu/drm/radeon/ni_dpm.c +++ b/drivers/gpu/drm/radeon/ni_dpm.c @@ -2741,10 +2741,10 @@ static int ni_set_mc_special_registers(struct radeon_device *rdev, table->mc_reg_table_entry[k].mc_data[j] |= 0x100; } j++; - if (j > SMC_NISLANDS_MC_REGISTER_ARRAY_SIZE) - return -EINVAL; break; case MC_SEQ_RESERVE_M >> 2: + if (j >= SMC_NISLANDS_MC_REGISTER_ARRAY_SIZE) + return -EINVAL; temp_reg = RREG32(MC_PMG_CMD_MRS1); table->mc_reg_address[j].s1 = MC_PMG_CMD_MRS1 >> 2; table->mc_reg_address[j].s0 = MC_SEQ_PMG_CMD_MRS1_LP >> 2; @@ -2753,8 +2753,6 @@ static int ni_set_mc_special_registers(struct radeon_device *rdev, (temp_reg & 0xffff0000) | (table->mc_reg_table_entry[k].mc_data[i] & 0x0000ffff); j++; - if (j > SMC_NISLANDS_MC_REGISTER_ARRAY_SIZE) - return -EINVAL; break; default: break; -- 2.35.1