Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1632347imu; Tue, 6 Nov 2018 01:37:45 -0800 (PST) X-Google-Smtp-Source: AJdET5dgsbE5TLAkObRGxhqI1Gd4WyTS0SskDl7WSrF4AzDmvK75FIkwS9xgwI3VkPYzWBwNVvFs X-Received: by 2002:a17:902:6686:: with SMTP id e6-v6mr10244321plk.173.1541497065145; Tue, 06 Nov 2018 01:37:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1541497065; cv=none; d=google.com; s=arc-20160816; b=KTf6a6OoPDwvu9/yvcy1elAy6ac6scYI/Fy3BnrA1WcK+LTWPsDxmq8FU7dHahzNAD ndKWf/2lL0AyupfaEVEldKl2+GQcjjlk8pb8EFFkCISUqQYW/iGDOBNilWTRdOVc7iiJ CDzjNvNOD9jrR25IT1o96JEbOJBP/DvGUF1F3YjCVsyheJ8M7VI1lyt2lPaMs4c+XkVa EEtWP5j5llH/j2/7gyEttatjpACNCt2Zqhw+bNUhUeKe8jIib+EMZwJ8lZhBgkSNIU3p c6wKPlFzcckQTeNwjKQVsRK802Vc8TfWQRcEACDCAsVtPhU1vgoXaw5VmqQQh4jHsODp vE1Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=KDqEXZM3w+csIzjnxMmBHNHjfzIeqE3gI4KtCaOk0j0=; b=kl444zsRPhzxpFE4JrYzxnfPwXnxRTTfEswWS7sWZqoCD3aFIS19Ej9K5aTaUm+54d EjCuLy9on0Iyiv83sUeId6lx9RLOudBQwkeNMdTOTBgrgJDUg9TpOt7putHwfinQL3JO DAByavWWmdiaICHNXUnqOLIA5Go7lODZ6Oz/81C3B5UeXvkDa2SvPpmJzAkAZ/SO3pko EWMXCDA3StnJd2Lyo8UG+O6lyJGsmRw0A6jGTefzHvRcVgYwDDgHHIwnd7X7EFxzFrcD z4iViZwzBTnEpE5e05NrR5G3HPkUMJQe5cT15aUDhyWvzfyMOPa79uxZv+V/yHxNjApm G3lw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=pmL2zpVS; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j185-v6si49998887pfc.186.2018.11.06.01.37.30; Tue, 06 Nov 2018 01:37:45 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=pmL2zpVS; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730178AbeKFS7g (ORCPT + 99 others); Tue, 6 Nov 2018 13:59:36 -0500 Received: from mail-wm1-f66.google.com ([209.85.128.66]:40057 "EHLO mail-wm1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729272AbeKFS7g (ORCPT ); Tue, 6 Nov 2018 13:59:36 -0500 Received: by mail-wm1-f66.google.com with SMTP id b203-v6so10852864wme.5 for ; Tue, 06 Nov 2018 01:35:14 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id; bh=KDqEXZM3w+csIzjnxMmBHNHjfzIeqE3gI4KtCaOk0j0=; b=pmL2zpVSBnifTkFiTyK0yKRJgTnXFpjBNNd9GuNRtJnRm/Ch+WKVL0MjkqavlwRsdG JQtF+IRmfG52hD/yF+1JFgVXZPHLIIzZXe9HlpZbT6tAk8AQOYWSXu/ZneeSwV/rVPww kr38RvhQ2soCdEye1zDgCz8wEm6M5hAVTQgfjjsIlFQ9DbDqbRrWWIbMV0LciLdpUV3W hTCXIiF7C8xcjwDXPI0Cn8/aVMQhacKX2qNxphvEfj4trnFhV74qpfRT5A1MIfm6XBPz eZw3edX6O2EqM0CAoTN77k7s8cnJhfB0RGRcVVcsGkjECjB9oTNlEs0zgip0nKTi5Ufo /H4A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=KDqEXZM3w+csIzjnxMmBHNHjfzIeqE3gI4KtCaOk0j0=; b=uDf//x3y6M7kp6QwMKF/LfVhtgWVmZ2t5BEgtjKji3BFHUnhKvun8hDH23PR9PMH/z cFQG6fxMPp/cIsAiv9EyxhRMGxqe/nbhpSHPntCAx89RlcLRlU2ND2Tl/qC72b1uo1Np gRVkuaAW7DeNXSQPiJyND/PeJR19IxcEHqx6R+m1qrQnGbXrmjBPbYrjvysDB06fPRmW YXC38t4JDjB8Y8usPkfK8YN46/aaGqddI3KzFf8O+P1ahYzBVeaO/Yy1xwxm0nAXtsBJ 9k+Ukzk/NeupmJbUT6yxUaCKw5aXLhz6SOZ7gYHLf3BGux2xYM1vdLsqxHQb1Hb1i0tq ellA== X-Gm-Message-State: AGRZ1gJ3ezJKEsUhupXgtGc8y9LU3tICuFI24ubzz7lq1SA8RPn0zKXI yOpyMt6QlXRPHXuOfNLiMrYtUg== X-Received: by 2002:a1c:ef15:: with SMTP id n21-v6mr1235921wmh.151.1541496913807; Tue, 06 Nov 2018 01:35:13 -0800 (PST) Received: from bender.baylibre.local ([90.63.244.31]) by smtp.gmail.com with ESMTPSA id i7-v6sm70402183wrb.30.2018.11.06.01.35.13 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Tue, 06 Nov 2018 01:35:13 -0800 (PST) From: Neil Armstrong To: dri-devel@lists.freedesktop.org Cc: Neil Armstrong , linux-amlogic@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH] drm/meson: Add HDMI 1.4 4k modes Date: Tue, 6 Nov 2018 10:35:09 +0100 Message-Id: <1541496909-19625-1-git-send-email-narmstrong@baylibre.com> X-Mailer: git-send-email 2.7.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add the timings for the HDMI 1.4 4K modes support : - 3840x2160@30 - 3840x2160@25 - 3840x2160@24 Since the 297000Hz pixel clock is already managed and the modes are compatible with the HDMI 1.4 current HDMI PHY+Controller support, only the missing timings values needs to be added. Signed-off-by: Neil Armstrong --- drivers/gpu/drm/meson/meson_venc.c | 129 +++++++++++++++++++++++++++++++++++++ 1 file changed, 129 insertions(+) diff --git a/drivers/gpu/drm/meson/meson_venc.c b/drivers/gpu/drm/meson/meson_venc.c index 514245e..bcffe8e 100644 --- a/drivers/gpu/drm/meson/meson_venc.c +++ b/drivers/gpu/drm/meson/meson_venc.c @@ -697,6 +697,132 @@ union meson_hdmi_venc_mode meson_hdmi_encp_mode_1080p60 = { }, }; +union meson_hdmi_venc_mode meson_hdmi_encp_mode_2160p24 = { + .encp = { + .dvi_settings = 0x1, + .video_mode = 0x4040, + .video_mode_adv = 0x8, + /* video_sync_mode */ + /* video_yc_dly */ + /* video_rgb_ctrl */ + .video_filt_ctrl = 0x1000, + .video_filt_ctrl_present = true, + /* video_ofld_voav_ofst */ + .yfp1_htime = 140, + .yfp2_htime = 140+3840, + .max_pxcnt = 3840+1660-1, + .hspuls_begin = 2156+1920, + .hspuls_end = 44, + .hspuls_switch = 44, + .vspuls_begin = 140, + .vspuls_end = 2059+1920, + .vspuls_bline = 0, + .vspuls_eline = 4, + .havon_begin = 148, + .havon_end = 3987, + .vavon_bline = 89, + .vavon_eline = 2248, + /* eqpuls_begin */ + /* eqpuls_end */ + /* eqpuls_bline */ + /* eqpuls_eline */ + .hso_begin = 44, + .hso_end = 2156+1920, + .vso_begin = 2100+1920, + .vso_end = 2164+1920, + .vso_bline = 51, + .vso_eline = 53, + .vso_eline_present = true, + /* sy_val */ + /* sy2_val */ + .max_lncnt = 2249, + }, +}; + +union meson_hdmi_venc_mode meson_hdmi_encp_mode_2160p25 = { + .encp = { + .dvi_settings = 0x1, + .video_mode = 0x4040, + .video_mode_adv = 0x8, + /* video_sync_mode */ + /* video_yc_dly */ + /* video_rgb_ctrl */ + .video_filt_ctrl = 0x1000, + .video_filt_ctrl_present = true, + /* video_ofld_voav_ofst */ + .yfp1_htime = 140, + .yfp2_htime = 140+3840, + .max_pxcnt = 3840+1440-1, + .hspuls_begin = 2156+1920, + .hspuls_end = 44, + .hspuls_switch = 44, + .vspuls_begin = 140, + .vspuls_end = 2059+1920, + .vspuls_bline = 0, + .vspuls_eline = 4, + .havon_begin = 148, + .havon_end = 3987, + .vavon_bline = 89, + .vavon_eline = 2248, + /* eqpuls_begin */ + /* eqpuls_end */ + /* eqpuls_bline */ + /* eqpuls_eline */ + .hso_begin = 44, + .hso_end = 2156+1920, + .vso_begin = 2100+1920, + .vso_end = 2164+1920, + .vso_bline = 51, + .vso_eline = 53, + .vso_eline_present = true, + /* sy_val */ + /* sy2_val */ + .max_lncnt = 2249, + }, +}; + +union meson_hdmi_venc_mode meson_hdmi_encp_mode_2160p30 = { + .encp = { + .dvi_settings = 0x1, + .video_mode = 0x4040, + .video_mode_adv = 0x8, + /* video_sync_mode */ + /* video_yc_dly */ + /* video_rgb_ctrl */ + .video_filt_ctrl = 0x1000, + .video_filt_ctrl_present = true, + /* video_ofld_voav_ofst */ + .yfp1_htime = 140, + .yfp2_htime = 140+3840, + .max_pxcnt = 3840+560-1, + .hspuls_begin = 2156+1920, + .hspuls_end = 44, + .hspuls_switch = 44, + .vspuls_begin = 140, + .vspuls_end = 2059+1920, + .vspuls_bline = 0, + .vspuls_eline = 4, + .havon_begin = 148, + .havon_end = 3987, + .vavon_bline = 89, + .vavon_eline = 2248, + /* eqpuls_begin */ + /* eqpuls_end */ + /* eqpuls_bline */ + /* eqpuls_eline */ + .hso_begin = 44, + .hso_end = 2156+1920, + .vso_begin = 2100+1920, + .vso_end = 2164+1920, + .vso_bline = 51, + .vso_eline = 53, + .vso_eline_present = true, + /* sy_val */ + /* sy2_val */ + .max_lncnt = 2249, + }, +}; + struct meson_hdmi_venc_vic_mode { unsigned int vic; union meson_hdmi_venc_mode *mode; @@ -717,6 +843,9 @@ struct meson_hdmi_venc_vic_mode { { 34, &meson_hdmi_encp_mode_1080p30 }, { 31, &meson_hdmi_encp_mode_1080p50 }, { 16, &meson_hdmi_encp_mode_1080p60 }, + { 93, &meson_hdmi_encp_mode_2160p24 }, + { 94, &meson_hdmi_encp_mode_2160p25 }, + { 95, &meson_hdmi_encp_mode_2160p30 }, { 0, NULL}, /* sentinel */ }; -- 2.7.4