Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3648997pxb; Mon, 24 Jan 2022 14:24:03 -0800 (PST) X-Google-Smtp-Source: ABdhPJxoLd78WAL5ZKIqtd/oUUr73ooy1J+b8QHXcM8Bgo/lHGeMQfgz8G50R8ERYh+rJSgI7y40 X-Received: by 2002:a63:6b89:: with SMTP id g131mr13176833pgc.221.1643063043410; Mon, 24 Jan 2022 14:24:03 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643063043; cv=none; d=google.com; s=arc-20160816; b=TIMtOZ08FKker4YLHDYDbX7jov2MGM/YlKOxvatR0VNGaKl7pwQcioADt2j6M9fCNV 8dRQ7E0EcHuPQPapoI1hcQaH3gFbh4oz0JcFEiP71jnMzgPotDZiv6pV8v4TEkeEvI69 j9mVSYY9yCb6ZgOExwsvM9RPM8zw20iP+9MH7lnhgEi7BWDfQxV0eTbwmelMiGeergZx Xc/uDxw2ALekis4uG1z+5aopObFy5wbziinSvt1MneYqoSE3+wv4q3ScpFP7MdARZS9Z JDTFJIlLWrLmrOsTOqRQuTrtOOmISOq9O6VqcP9pXswhsmpBAIytBdmWPXN8JxNufwGS QSVQ== 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=biVOBQPF33jrue+Fj1lsqe3XfVxKq+E8c65bzg1iWTc=; b=Px7yySSGlaLFwNWDjRR+I887hVupZiQUPD6NNd1VI0yDopxPTgpQ3hULw3oW02eHd4 4IJWXsmBwO+fUYoTebvtxcbOg/xnFNsbS65FQUjgj+bqpkVkOEgjn0CwpD2REYM4jUDy ReN08pwkl4OjKcK+vTMebz6/96Pbb2ZqSlqsxrCGjgl+ezmMkCIOIEw4D9UoHmurJe2g aKk+5DxxVVf4YPHCGrNshFKkUBXV349S03v8UhMFhr75VP3E2bztD2f8MHXXkVY4C7HK sm2iwerGB9CSSTHBVOAHul2VT0nABNFvd3AqVn27IYSRbb2MiIDy2bv26k+FZFZs2pEu ZSGA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=zoyxdZYI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.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 vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a3si8054515pgv.252.2022.01.24.14.23.46; Mon, 24 Jan 2022 14:24:03 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=zoyxdZYI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.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: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1582810AbiAXWP4 (ORCPT + 99 others); Mon, 24 Jan 2022 17:15:56 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52818 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1453885AbiAXVbI (ORCPT ); Mon, 24 Jan 2022 16:31:08 -0500 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 63FDDC0AD1AC; Mon, 24 Jan 2022 12:19:50 -0800 (PST) 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 033A361496; Mon, 24 Jan 2022 20:19:50 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id C7ECDC340E5; Mon, 24 Jan 2022 20:19:48 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643055589; bh=FCtfFY34iZEwAr7Qu9zfh7qbShfAkumL+e4sa31RBqc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=zoyxdZYIE2VGAc/SJ6QvLqtzFTRg+DnVJ3CAAOXCtls/Rcjmebz0T/QBI/BDEOitB tsv/WfXR1M/YGBHPoAAWsTq0Q3xsebdk6/dgnQQeE/kfzq8MnseMJVI0WzPUf988PS bykC0Qn3ApnxwZGsLfR0Pn06q11WXVph6jPjXSGo= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Zhou Qingyang , Alex Deucher , Sasha Levin Subject: [PATCH 5.15 183/846] drm/amdgpu: Fix a NULL pointer dereference in amdgpu_connector_lcd_native_mode() Date: Mon, 24 Jan 2022 19:35:00 +0100 Message-Id: <20220124184107.286268254@linuxfoundation.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124184100.867127425@linuxfoundation.org> References: <20220124184100.867127425@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Zhou Qingyang [ Upstream commit b220110e4cd442156f36e1d9b4914bb9e87b0d00 ] In amdgpu_connector_lcd_native_mode(), the return value of drm_mode_duplicate() is assigned to mode, and there is a dereference of it in amdgpu_connector_lcd_native_mode(), which will lead to a NULL pointer dereference on failure of drm_mode_duplicate(). Fix this bug add a check of mode. This bug was found by a static analyzer. The analysis employs differential checking to identify inconsistent security operations (e.g., checks or kfrees) between two code paths and confirms that the inconsistent operations are not recovered in the current function or the callers, so they constitute bugs. Note that, as a bug found by static analysis, it can be a false positive or hard to trigger. Multiple researchers have cross-reviewed the bug. Builds with CONFIG_DRM_AMDGPU=m show no new warnings, and our static analyzer no longer warns about this code. Fixes: d38ceaf99ed0 ("drm/amdgpu: add core driver (v4)") Signed-off-by: Zhou Qingyang Signed-off-by: Alex Deucher Signed-off-by: Sasha Levin --- drivers/gpu/drm/amd/amdgpu/amdgpu_connectors.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_connectors.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_connectors.c index 0de66f59adb8a..df1f9b88a53f9 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_connectors.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_connectors.c @@ -387,6 +387,9 @@ amdgpu_connector_lcd_native_mode(struct drm_encoder *encoder) native_mode->vdisplay != 0 && native_mode->clock != 0) { mode = drm_mode_duplicate(dev, native_mode); + if (!mode) + return NULL; + mode->type = DRM_MODE_TYPE_PREFERRED | DRM_MODE_TYPE_DRIVER; drm_mode_set_name(mode); @@ -401,6 +404,9 @@ amdgpu_connector_lcd_native_mode(struct drm_encoder *encoder) * simpler. */ mode = drm_cvt_mode(dev, native_mode->hdisplay, native_mode->vdisplay, 60, true, false, false); + if (!mode) + return NULL; + mode->type = DRM_MODE_TYPE_PREFERRED | DRM_MODE_TYPE_DRIVER; DRM_DEBUG_KMS("Adding cvt approximation of native panel mode %s\n", mode->name); } -- 2.34.1