Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp3023753pxb; Mon, 18 Oct 2021 06:49:01 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyHVuJw6sDCwYSNYeo3M3lPK50DwLYQZ0s9tA9InmCgFAbaie4pmem9mrqxy1DpFg3vOvIk X-Received: by 2002:a62:1887:0:b0:44c:872e:27ed with SMTP id 129-20020a621887000000b0044c872e27edmr28598445pfy.71.1634564940849; Mon, 18 Oct 2021 06:49:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634564940; cv=none; d=google.com; s=arc-20160816; b=zTHVYiSqe3kyFWpGjy2TKGfjNfkWg6Gwy5jNKDrScelV7Q4KVFppllcVSeMwoIndXq xWF8w2Nkl7kJ1o0C5vn4rFhYZK0O5J7RhVXKYbpKYgTbiwkqVHr5s50jTHv1Qt8uvfha mvPrLx2iRslzs5oyCIQBL/7dlauyYvFcVM7G9IzHHuayeBbDUvLR+HSueRgA3X8C7SeR OyA5jT3Kj5yEpL1MrcHbIe/4tf5zxiNLRGHe8xM+y9Czo2iv/d7rkyoI78akKm+FDJoh Lu3Q58alDE6dOrvoE6paK1BMfq489RVe2qdPdS+LEBOzwdiy71vHY2FCsiEkfqfv73CD L+Dw== 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=WjwXJreDPnnr7Gwvs2+FI91RAHFii5KAtlRbx6G1pDE=; b=R0UV7ut7g2XiWfiB+NY+zLtOfDkAG1JIurlgSvdUnvFF06EfscY0h8YR3O8CpUvGlq mpwJX4XoXmlX/J4o3J0Iu3n5HQ8dJxzn8bnc7zhg+jHyzZ/wzfpbdbDim/hFyht6es0E 0v5NfWVARyHtJCFDqwFU9nnZQt7X3vQRqR16YMo557uirMCxjFpFZ/6ew0QjdWcYIk27 uhVq2EyVsOpnS2dEaeEb4eI6uP8GcdC4U3JouMPkMTdLr6L0Jpyocrt/BMft0yX26/YL jb4FiPrRmXBU51NCYhibgJUC7Ch0UBiuKKE//cWg1B0ZI8swNJMKK29adyJaUEVbMw6M mNBQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=DyM78QTx; 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 p3si24952741pfh.201.2021.10.18.06.48.48; Mon, 18 Oct 2021 06:49:00 -0700 (PDT) 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=DyM78QTx; 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 S232025AbhJRNst (ORCPT + 99 others); Mon, 18 Oct 2021 09:48:49 -0400 Received: from mail.kernel.org ([198.145.29.99]:40222 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232019AbhJRNqR (ORCPT ); Mon, 18 Oct 2021 09:46:17 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id CA345615E3; Mon, 18 Oct 2021 13:36:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1634564162; bh=LPBpZ1pxDWZuPDwEUK+cZZQ+4RE9MfJW6xmxK5RsY88=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=DyM78QTxF8rTuZII7dVQnN4R0+1RbAC4F/Q7aAN/ohSz71Nx/dnalbAtz1tYUUOOh O5PlotfmmzMa2mpJiKDoyfQPBL1TVyRH29XsDDHCSljg1iQiMBFsx68q6xnramlU0d 2kSAxW5/Ia7TkSIrVUZVA+8q0wVcwqyHsfDnadeQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, =?UTF-8?q?Ville=20Syrj=C3=A4l=C3=A4?= , Douglas Anderson , Dave Airlie Subject: [PATCH 5.10 089/103] drm/edid: In connector_bad_edid() cap num_of_ext by num_blocks read Date: Mon, 18 Oct 2021 15:25:05 +0200 Message-Id: <20211018132337.740474080@linuxfoundation.org> X-Mailer: git-send-email 2.33.1 In-Reply-To: <20211018132334.702559133@linuxfoundation.org> References: <20211018132334.702559133@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: Douglas Anderson commit 97794170b696856483f74b47bfb6049780d2d3a0 upstream. In commit e11f5bd8228f ("drm: Add support for DP 1.4 Compliance edid corruption test") the function connector_bad_edid() started assuming that the memory for the EDID passed to it was big enough to hold `edid[0x7e] + 1` blocks of data (1 extra for the base block). It completely ignored the fact that the function was passed `num_blocks` which indicated how much memory had been allocated for the EDID. Let's fix this by adding a bounds check. This is important for handling the case where there's an error in the first block of the EDID. In that case we will call connector_bad_edid() without having re-allocated memory based on `edid[0x7e]`. Fixes: e11f5bd8228f ("drm: Add support for DP 1.4 Compliance edid corruption test") Reported-by: Ville Syrjälä Signed-off-by: Douglas Anderson Reviewed-by: Ville Syrjälä Link: https://patchwork.freedesktop.org/patch/msgid/20211005192905.v2.1.Ib059f9c23c2611cb5a9d760e7d0a700c1295928d@changeid Signed-off-by: Dave Airlie Signed-off-by: Greg Kroah-Hartman --- drivers/gpu/drm/drm_edid.c | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) --- a/drivers/gpu/drm/drm_edid.c +++ b/drivers/gpu/drm/drm_edid.c @@ -1835,11 +1835,20 @@ static void connector_bad_edid(struct dr u8 *edid, int num_blocks) { int i; - u8 num_of_ext = edid[0x7e]; + u8 last_block; + + /* + * 0x7e in the EDID is the number of extension blocks. The EDID + * is 1 (base block) + num_ext_blocks big. That means we can think + * of 0x7e in the EDID of the _index_ of the last block in the + * combined chunk of memory. + */ + last_block = edid[0x7e]; /* Calculate real checksum for the last edid extension block data */ - connector->real_edid_checksum = - drm_edid_block_checksum(edid + num_of_ext * EDID_LENGTH); + if (last_block < num_blocks) + connector->real_edid_checksum = + drm_edid_block_checksum(edid + last_block * EDID_LENGTH); if (connector->bad_edid_counter++ && !drm_debug_enabled(DRM_UT_KMS)) return;