From patchwork Fri Jan 10 07:44:57 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Hewitt X-Patchwork-Id: 13933919 X-Patchwork-Delegate: neil.armstrong@linaro.org Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id C6992E7719C for ; Fri, 10 Jan 2025 07:46:25 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:References:In-Reply-To: Message-Id:Date:Subject:Cc:To:From:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=/rDVmU0RKUuAiegkuSu0h6mkQY88oSpk8dxr/p4P4rs=; b=VIhUbUSxhE7Y9o JANiHHFFgcTuGLoyiDjqBr68ZccCrSkJ0GvLKLotGq+1y48qGpadwBa0GCJ+pvdozHCIYcTWFrdsj tsXBpAbhsKp1F5rcwD+qGV4rG29a4fv3VRWOhEChxj2LM33+S/QCgC9gbjXe3Gr2jRmNzrRb5ezUp mhdsC3yRbNT0aCL9+ZSODdAs1/kIhmVjbJEShNItXZMwyiIE90bJLnup86bfvjqt9DGfL630fjAgt xTO5GRVc/oxzShXfeaubrK34sC6oWcMpOnFEP2kPj0g/9LfkGw3Gt4Sa9tgg9JgK7AUK40unMF/Pe IiNWuJGxpiHqPisIYvyg==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1tW9io-0000000EQVA-2y3q; Fri, 10 Jan 2025 07:46:22 +0000 Received: from mail-wm1-x32d.google.com ([2a00:1450:4864:20::32d]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1tW9hc-0000000EQ9k-3oCy; Fri, 10 Jan 2025 07:45:10 +0000 Received: by mail-wm1-x32d.google.com with SMTP id 5b1f17b1804b1-43625c4a50dso13281525e9.0; Thu, 09 Jan 2025 23:45:08 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1736495107; x=1737099907; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=ATDsjAK0uKMKhFaAu8bbQjJc2CPGx/RtQGrifkWV5pE=; b=i06yVC2OJQiP0u7MpGyfycAXBV2EPgONQ/CPypieXlSa8/jbRnrt4DWK0HV+JkNhZE ZnN2g0lOZLJDXU3RrhvlGrSbQaMvzYXpB9l0dVCt3hyw/Vr2ibkng4ttPzl5rlJxXX1x vkBMNJ6fBl0hSP4fPlirlcSDYqRBVbPSKqtMSxyNWKGob/EHKlyEOSGTYimDkLepJzBE YXG4s/qobZBPBQ+OxcDjKP5HV9cCTC0156HWGtZTsLt1MBXIw7lDICxYVvQN54qXCx8p WwcW2LQ0yV7m3WuadS1So54w8MqQouuHKvl1OZXTfYLwNhQDODzeB83pudyMeauhOZLE IOCg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1736495107; x=1737099907; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=ATDsjAK0uKMKhFaAu8bbQjJc2CPGx/RtQGrifkWV5pE=; b=r1vDWBRi+O1n3pyJyo8/iQk8w+p1G0WMj+LGc+tV9Zjtkptt5IhHf69sxkG1PdWZHa 6R0yeXaCQGzrcV7Bgl7I9TS1ecMbipjO5HkLRKrIlrN6sb3VXjGjG3OXNETxpV91NWsg v+I+HOcGWiPk9xGr/s6x3Ppamu2mg8bW/zVNXOG3u40oezh2s1AeZNs6mcDKyusv9SH0 QsbGFxb+NVZqMDZ0nR5tLxx/Hg3AjCfPTYz/eCxflcT7SMFsc3hJIJlsAxGVEQKhv1R/ XmWL39KAxi/wcLNzzkgANiEpSNwoVykFpuFjOaHCv5pYWFP858Qr6kgOZzieEf3LCdJw el9g== X-Forwarded-Encrypted: i=1; AJvYcCUaYli+8JMgUBkdv3+BHibNxriGQfTIwvvuWZGlVE4Vug5mYcNgci41j49Puc1XLYPZC/TPmrVEiyJJVeYVtF52iA==@lists.infradead.org, AJvYcCW5Hu+3hBafY7hBArRfu/KEVpiXo1Sz8GmzIQ0xFGaE9eqDgZUxqjcW1BcxW1yHvm4vRfTSOAOIE+nTFyzf@lists.infradead.org X-Gm-Message-State: AOJu0Yxs9uGckzR2G7GvRq4sNzQDrwN8G6BoHFD3LJ5ctladtSsd+BH3 FmDVx8Mq9HYofN2lW0MWFfrqgG/9ER7iFOCulbiTNsUaIC+goLZV X-Gm-Gg: ASbGnctNrXgtAcn9DSx/ZJUHRPiBlQKA8uRbfAdXbm07x2pfbgGkbXzD86MTRlXJcq5 01vh/P5oRQt1nsVDIQlqEa7ldFFWDNxEavUZTbsg10ua+PhyAsWk8Kgv/QcsP7ZdzHKYcMVXkBQ 4M+nAO6UZRm2YJmreKUsJX7eqVtPXcEi8o17Y07qEKFBkCHqnV/gLnNJGk8Zi9vKMkxtqRdD2XB yTuk6ZuLqX9yh9ZLWaTJ5MdvIp909YEJCOMrJZT0y7hEqEno05VZ6Nfy3RO3g== X-Google-Smtp-Source: AGHT+IGb+vzb8Pe/v6kmaLVgm8KOUcAV6AU7z/JagMZlqc8SrieF7wsh7dlW2Vj7FxtpiiwFRDJhZQ== X-Received: by 2002:a05:600c:3c85:b0:434:a802:e99a with SMTP id 5b1f17b1804b1-436e267821emr85597015e9.4.1736495106968; Thu, 09 Jan 2025 23:45:06 -0800 (PST) Received: from toolbox.. ([87.200.95.144]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-436e2e8a326sm78547995e9.35.2025.01.09.23.45.04 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 09 Jan 2025 23:45:06 -0800 (PST) From: Christian Hewitt To: Neil Armstrong , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , Kevin Hilman , Jerome Brunet , Martin Blumenstingl , Jernej Skrabec , dri-devel@lists.freedesktop.org, linux-amlogic@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Cc: stable@vger.kernel.org Subject: [PATCH 1/2] Revert "drm/meson: vclk: fix calculation of 59.94 fractional rates" Date: Fri, 10 Jan 2025 07:44:57 +0000 Message-Id: <20250110074458.3624094-2-christianshewitt@gmail.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20250110074458.3624094-1-christianshewitt@gmail.com> References: <20250110074458.3624094-1-christianshewitt@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250109_234508_945774_AE789819 X-CRM114-Status: GOOD ( 11.67 ) X-BeenThere: linux-amlogic@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-amlogic" Errors-To: linux-amlogic-bounces+linux-amlogic=archiver.kernel.org@lists.infradead.org This reverts commit bfbc68e4d8695497f858a45a142665e22a512ea3. The patch does permit the offending YUV420 @ 59.94 phy_freq and vclk_freq mode to match in calculations. It also results in all fractional rates being unavailable for use. This was unintended and requires the patch to be reverted. Cc: Signed-off-by: Christian Hewitt --- drivers/gpu/drm/meson/meson_vclk.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/drivers/gpu/drm/meson/meson_vclk.c b/drivers/gpu/drm/meson/meson_vclk.c index 2a942dc6a6dc..2a82119eb58e 100644 --- a/drivers/gpu/drm/meson/meson_vclk.c +++ b/drivers/gpu/drm/meson/meson_vclk.c @@ -790,13 +790,13 @@ meson_vclk_vic_supported_freq(struct meson_drm *priv, unsigned int phy_freq, FREQ_1000_1001(params[i].pixel_freq)); DRM_DEBUG_DRIVER("i = %d phy_freq = %d alt = %d\n", i, params[i].phy_freq, - FREQ_1000_1001(params[i].phy_freq/1000)*1000); + FREQ_1000_1001(params[i].phy_freq/10)*10); /* Match strict frequency */ if (phy_freq == params[i].phy_freq && vclk_freq == params[i].vclk_freq) return MODE_OK; /* Match 1000/1001 variant */ - if (phy_freq == (FREQ_1000_1001(params[i].phy_freq/1000)*1000) && + if (phy_freq == (FREQ_1000_1001(params[i].phy_freq/10)*10) && vclk_freq == FREQ_1000_1001(params[i].vclk_freq)) return MODE_OK; } @@ -1070,7 +1070,7 @@ void meson_vclk_setup(struct meson_drm *priv, unsigned int target, for (freq = 0 ; params[freq].pixel_freq ; ++freq) { if ((phy_freq == params[freq].phy_freq || - phy_freq == FREQ_1000_1001(params[freq].phy_freq/1000)*1000) && + phy_freq == FREQ_1000_1001(params[freq].phy_freq/10)*10) && (vclk_freq == params[freq].vclk_freq || vclk_freq == FREQ_1000_1001(params[freq].vclk_freq))) { if (vclk_freq != params[freq].vclk_freq) From patchwork Fri Jan 10 07:44:58 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Hewitt X-Patchwork-Id: 13933920 X-Patchwork-Delegate: neil.armstrong@linaro.org Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 2E3AFE7719D for ; Fri, 10 Jan 2025 07:47:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:References:In-Reply-To: Message-Id:Date:Subject:To:From:Reply-To:Cc:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=qApuX7DVAZsejqlsGKu+j/lylMvN7FxWnm8UJv4cDNU=; b=wLPl4pSjfcMGZv LoJteiMdAkt+urXqH/VQGNYYQAT40ZxhDlEcv4E4CiKA8ubmWgeYImElVieSABKGOkYrc0K5+o+zD T56yQQsS1JYjLj6KUJVaVmfznTxzscSOVRcLh9wm3SGlDZlG0xpb74gnvnm+o5sx7Pj2UXFyZDjms nSSVW1fGOoa1tse7+D6Beu2BiVohGceyHfsorvh2+CZ+05cmiJ5zN5nFkxc+Pa4OYQ1dkh+Qgq1ao Gdg7GrUOKGwlRDKsQuA4toAwgv7vHhIGGm6KgCvc4/f84N7hNACvyc4zqq93ya9gpIDzZN43MglEo NlquYZwh5NxyaRySZP1A==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1tW9k0-0000000EQu4-3DnB; Fri, 10 Jan 2025 07:47:36 +0000 Received: from mail-wr1-x42d.google.com ([2a00:1450:4864:20::42d]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1tW9hf-0000000EQAz-3VZN; Fri, 10 Jan 2025 07:45:13 +0000 Received: by mail-wr1-x42d.google.com with SMTP id ffacd0b85a97d-38632b8ae71so1195789f8f.0; Thu, 09 Jan 2025 23:45:11 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1736495110; x=1737099910; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=2jNHP4kZ+vx7B4mNnjwcHbIWUQy7cq2XYj5Zl2+8UJQ=; b=ONmp9EEv4k5oMc5SFU0NKRSA0Ju/P2gqQkpLoJXUd4RMkmhCmkjXvTsvovoH2v5dBk cLnRVxhZsLiGVhqXuMpfrsvUYYpc5MFiAcnGbE+jw6q9pMfhI/A9ItdokWVEv5HSIX+2 ufh+YU99hO5q7+0Fm7RsExzm481zXOEZaEDEpPXG+g97ptgr2DJIy6GiKdUonz62Z5QM qIX4mEWXjt+tijy1/mixHah7+P46YmSgey/uQkc/vhG08+JYBiDXxsqvIwFG7lgrAHAq 4D9CTkiXi9cRKF/Q5SQXedRC/VZ9hf3mvZl+GqJu9tUE+ktAR+AC/HC/p/jfm4BWqQpS vTkQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1736495110; x=1737099910; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=2jNHP4kZ+vx7B4mNnjwcHbIWUQy7cq2XYj5Zl2+8UJQ=; b=MogUocLyRkkHPzeAvU6ocMTcuHJ8+QeBmN1PyYYY5PenSRIP7GGOoxMXw4gZUSjc9/ 8OW2j3mnbYdTnhRC/6YAASJbTNUgl6hp4gQoTTzCLSOZ0ijk8e9Zh0q7clSBFflcDYsF QTEPBsQid7FIEikjvyjEfsnz2d2z4btIw6WM6cxQeI3yEVtzTXJhTRSqEeQ7bA/ViZdl ItjWgKoQ/tDkX8nCAw2C3qDfw+c64ejn5i6kF/JoFDI8TtjPDe6s+UIubTFaRJzTV/2T WY+WyBeUZstzV+yDF+jG9JpFMbgEpYdr7l7hdMI/1V8iWNygMBQhIs3+p5ZgOXaQflDV k39g== X-Forwarded-Encrypted: i=1; AJvYcCWR/9FvEFyvUjAlRxd6SV/IvBjT6rE37lxGasUVKYMrhwj2Xr4/gQ0Wk4SUQ0ELF49NrOHfNqmS6zsBNYGG@lists.infradead.org, AJvYcCX9q2PELiFoywtDM3MpjlgaqywZIyihoDDzggokyr93nTRhCCaQ0Mo8Cb6o10fFF5xT80t0d5uVgyilkPh1MRtVLQ==@lists.infradead.org X-Gm-Message-State: AOJu0Yz3TLr3S1VXv2iUGoMjNbso6LV7tlsgL5C6ajxHelPOY16+8NS2 UqPILOUXThExhU+CJ6sPi70sXgm2zFWzMwx5uOUp5cW8Iw05gOMaZhCnBqhd X-Gm-Gg: ASbGncs+gLuGxr1btrYPzv41XCJ4TvHWlEAnOM3f/Cp5o2Yxu0fqpGYmLkhzqldbQao JbU11MXybIH7L7rmHhwS1q87SPTx0+7ck+KHfnBVgn3TQB/LbQ7mNrA4vkmYrBuzvGcirQBSZFR KcIKIVnONmXwsAGMy01DSL1p321iaeQWGpK/7RoTCNd+bAE2a8rL23zEFZwtscoNwgzW7M3JfWh Pot/GyKze4tn9ysNxLCnoOSowvb0HG7kNBidx5Ek80NnJRAmdXTQmjbgFldcg== X-Google-Smtp-Source: AGHT+IEWgMeyWDOA+o/1zzBIG4lq5Hb3irgWYUor5mMfHYLLxUho1JaxY7qlzPernGP85Damom0BMw== X-Received: by 2002:a5d:5f8f:0:b0:38a:2b39:679d with SMTP id ffacd0b85a97d-38a87313e2cmr8298382f8f.32.1736495109806; Thu, 09 Jan 2025 23:45:09 -0800 (PST) Received: from toolbox.. ([87.200.95.144]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-436e2e8a326sm78547995e9.35.2025.01.09.23.45.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 09 Jan 2025 23:45:09 -0800 (PST) From: Christian Hewitt To: Neil Armstrong , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , Kevin Hilman , Jerome Brunet , Martin Blumenstingl , Jernej Skrabec , dri-devel@lists.freedesktop.org, linux-amlogic@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH 2/2] drm/meson: vclk: fix precision in vclk calculations Date: Fri, 10 Jan 2025 07:44:58 +0000 Message-Id: <20250110074458.3624094-3-christianshewitt@gmail.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20250110074458.3624094-1-christianshewitt@gmail.com> References: <20250110074458.3624094-1-christianshewitt@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250109_234511_911638_B471EFBC X-CRM114-Status: GOOD ( 15.93 ) X-BeenThere: linux-amlogic@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-amlogic" Errors-To: linux-amlogic-bounces+linux-amlogic=archiver.kernel.org@lists.infradead.org Playing YUV420 @ 59.94 media causes HDMI output to lose sync with a fatal error reported: [ 89.610280] Fatal Error, invalid HDMI vclk freq 593406 In meson_encoder_hdmi_set_vclk the initial vclk_freq value is 593407 but YUV420 modes halve the value to 296703.5 and this is stored as int which loses precision by rounding down to 296703. The rounded value is later doubled to 593406 and then meson_encoder_hdmi_set_vclk sets an invalid vclk_freq value and the error triggers during meson_vlkc_setup validation. Fix precision in meson_encoder_hdmi_set_vclk by switching to unsigned long long KHz values instead of int MHz. As values for phy_freq are now more accurate we also need to handle an additional match scenario in meson_vclk_setup. Fixes: e5fab2ec9ca4 ("drm/meson: vclk: add support for YUV420 setup") Signed-off-by: Christian Hewitt --- drivers/gpu/drm/meson/meson_encoder_hdmi.c | 42 +++++++++++----------- drivers/gpu/drm/meson/meson_vclk.c | 3 +- 2 files changed, 23 insertions(+), 22 deletions(-) diff --git a/drivers/gpu/drm/meson/meson_encoder_hdmi.c b/drivers/gpu/drm/meson/meson_encoder_hdmi.c index 0593a1cde906..fa37cf975992 100644 --- a/drivers/gpu/drm/meson/meson_encoder_hdmi.c +++ b/drivers/gpu/drm/meson/meson_encoder_hdmi.c @@ -70,12 +70,12 @@ static void meson_encoder_hdmi_set_vclk(struct meson_encoder_hdmi *encoder_hdmi, { struct meson_drm *priv = encoder_hdmi->priv; int vic = drm_match_cea_mode(mode); - unsigned int phy_freq; - unsigned int vclk_freq; - unsigned int venc_freq; - unsigned int hdmi_freq; + unsigned long long vclk_freq; + unsigned long long phy_freq; + unsigned long long venc_freq; + unsigned long long hdmi_freq; - vclk_freq = mode->clock; + vclk_freq = mode->clock * 1000ULL; /* For 420, pixel clock is half unlike venc clock */ if (encoder_hdmi->output_bus_fmt == MEDIA_BUS_FMT_UYYVYY8_0_5X24) @@ -85,8 +85,9 @@ static void meson_encoder_hdmi_set_vclk(struct meson_encoder_hdmi *encoder_hdmi, phy_freq = vclk_freq * 10; if (!vic) { - meson_vclk_setup(priv, MESON_VCLK_TARGET_DMT, phy_freq, - vclk_freq, vclk_freq, vclk_freq, false); + meson_vclk_setup(priv, MESON_VCLK_TARGET_DMT, phy_freq / 1000ULL, + vclk_freq / 1000ULL, vclk_freq / 1000ULL, + vclk_freq / 1000ULL, false); return; } @@ -107,12 +108,9 @@ static void meson_encoder_hdmi_set_vclk(struct meson_encoder_hdmi *encoder_hdmi, if (mode->flags & DRM_MODE_FLAG_DBLCLK) venc_freq /= 2; - dev_dbg(priv->dev, "vclk:%d phy=%d venc=%d hdmi=%d enci=%d\n", - phy_freq, vclk_freq, venc_freq, hdmi_freq, - priv->venc.hdmi_use_enci); - - meson_vclk_setup(priv, MESON_VCLK_TARGET_HDMI, phy_freq, vclk_freq, - venc_freq, hdmi_freq, priv->venc.hdmi_use_enci); + meson_vclk_setup(priv, MESON_VCLK_TARGET_HDMI, phy_freq / 1000ULL, + vclk_freq / 1000ULL, venc_freq / 1000ULL, hdmi_freq / 1000ULL, + priv->venc.hdmi_use_enci); } static enum drm_mode_status meson_encoder_hdmi_mode_valid(struct drm_bridge *bridge, @@ -122,10 +120,10 @@ static enum drm_mode_status meson_encoder_hdmi_mode_valid(struct drm_bridge *bri struct meson_encoder_hdmi *encoder_hdmi = bridge_to_meson_encoder_hdmi(bridge); struct meson_drm *priv = encoder_hdmi->priv; bool is_hdmi2_sink = display_info->hdmi.scdc.supported; - unsigned int phy_freq; - unsigned int vclk_freq; - unsigned int venc_freq; - unsigned int hdmi_freq; + unsigned long long vclk_freq; + unsigned long long phy_freq; + unsigned long long venc_freq; + unsigned long long hdmi_freq; int vic = drm_match_cea_mode(mode); enum drm_mode_status status; @@ -149,7 +147,7 @@ static enum drm_mode_status meson_encoder_hdmi_mode_valid(struct drm_bridge *bri } else if (!meson_venc_hdmi_supported_vic(vic)) return MODE_BAD; - vclk_freq = mode->clock; + vclk_freq = mode->clock * 1000ULL; /* For 420, pixel clock is half unlike venc clock */ if (drm_mode_is_420_only(display_info, mode) || @@ -179,10 +177,12 @@ static enum drm_mode_status meson_encoder_hdmi_mode_valid(struct drm_bridge *bri if (mode->flags & DRM_MODE_FLAG_DBLCLK) venc_freq /= 2; - dev_dbg(priv->dev, "%s: vclk:%d phy=%d venc=%d hdmi=%d\n", - __func__, phy_freq, vclk_freq, venc_freq, hdmi_freq); + dev_dbg(priv->dev, "%s: phy=%lld vclk=%lld venc=%lld hdmi=%lld\n", + __func__, phy_freq / 1000ULL, vclk_freq / 1000ULL, + venc_freq / 1000ULL, hdmi_freq / 1000ULL); - return meson_vclk_vic_supported_freq(priv, phy_freq, vclk_freq); + return meson_vclk_vic_supported_freq(priv, phy_freq / 1000ULL, + vclk_freq / 1000ULL); } static void meson_encoder_hdmi_atomic_enable(struct drm_bridge *bridge, diff --git a/drivers/gpu/drm/meson/meson_vclk.c b/drivers/gpu/drm/meson/meson_vclk.c index 2a82119eb58e..a2e93b500ed6 100644 --- a/drivers/gpu/drm/meson/meson_vclk.c +++ b/drivers/gpu/drm/meson/meson_vclk.c @@ -1070,7 +1070,8 @@ void meson_vclk_setup(struct meson_drm *priv, unsigned int target, for (freq = 0 ; params[freq].pixel_freq ; ++freq) { if ((phy_freq == params[freq].phy_freq || - phy_freq == FREQ_1000_1001(params[freq].phy_freq/10)*10) && + phy_freq == FREQ_1000_1001(params[freq].phy_freq/10)*10 || + ((phy_freq/10)*10) == FREQ_1000_1001(params[freq].phy_freq/10)*10) && (vclk_freq == params[freq].vclk_freq || vclk_freq == FREQ_1000_1001(params[freq].vclk_freq))) { if (vclk_freq != params[freq].vclk_freq)