Received: by 2002:a05:7412:31a9:b0:e2:908c:2ebd with SMTP id et41csp667341rdb; Fri, 8 Sep 2023 12:17:39 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEthAWYdA9fTWAC4HENWiHPLRkc2FXMrJhri2+JAMSaIdCpZ605VBnKPbN3XbjnyneFxpNt X-Received: by 2002:a05:6a20:5655:b0:14d:cca3:a100 with SMTP id is21-20020a056a20565500b0014dcca3a100mr3486729pzc.36.1694200659604; Fri, 08 Sep 2023 12:17:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1694200659; cv=none; d=google.com; s=arc-20160816; b=Xv7E3DSzOg3KjKVIvJS72vvNt3ckiogaD1XVPLnN32muzc40KIgUE9qgeh83o0jGeQ SRjyauA/VgV462Gtkp18ZoYk3QdCrU6tp+q+Pr3r6XBhUUZrmdDU8P04637UXFpFmct9 g6dzlMd9rYKdH/IRXrrOCcfL3V1jcj+/QUl5OrgDldb+tL8BU6eE1KcKr/nD1GrUMeFh NmrC11LRZievY8/fLfNcyqB2zaNuntDw66XLEGLTERT9ZO/jb3Syczx8/aw1QBwwfzab N0Mhkpxg1ZXQvGneReWV3OloVVzmAL4qAi5zYegN2aYAGpCU1xzlLchbq2E7tF1LCwr1 3WIQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=7CsbEU9fx8LTBLkq6AyVZmjr235jVh/NHMPa791ymNE=; fh=aD4nzDFgC0UZ1Hnc4/XaW5rKm2zwKzUzHo+lLTvbbP8=; b=aYmZhOo0sOyq7dIwBExXt9I3YwQBDBEPUHjqKtYWvlx/fGU63z7wnNrxr74pECWId2 EAEZa/TNNpy7zPIhDI+ntJ6VS3nnep0MdyyYdG3w+IoWfLE1Jr2pXanCe1cLjgF+eIm9 pkbnZyM777Upa0rIh9T3EOFwni8zdFMNOgByQEAl+sznlwvNKFKgCTS2kb81riw0W36S /1fw6pEDd6fv1cgjEaopHitm5x090stGYwKxsEThuViSNuqL+NiwdXyPJS+NiF63z+uA VUGAVts2+GPWdZi3D4NvuoZTifpr1SAS4Nl9EgcB0qiJNHsGpCjDsqMNOSonP/mF9/WM Lffw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@igalia.com header.s=20170329 header.b="Ft/dtsQy"; 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id v202-20020a6361d3000000b00573fcaea385si1804209pgb.235.2023.09.08.12.17.20; Fri, 08 Sep 2023 12:17:39 -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=fail header.i=@igalia.com header.s=20170329 header.b="Ft/dtsQy"; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239737AbjIHOuR (ORCPT + 99 others); Fri, 8 Sep 2023 10:50:17 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60746 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242959AbjIHOuN (ORCPT ); Fri, 8 Sep 2023 10:50:13 -0400 Received: from fanzine2.igalia.com (fanzine.igalia.com [178.60.130.6]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 09E901FC0 for ; Fri, 8 Sep 2023 07:50:06 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=igalia.com; s=20170329; h=In-Reply-To:Content-Type:MIME-Version:References:Message-ID: Subject:Cc:To:From:Date:Sender:Reply-To:Content-Transfer-Encoding:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:List-Id:List-Help:List-Unsubscribe:List-Subscribe: List-Post:List-Owner:List-Archive; bh=7CsbEU9fx8LTBLkq6AyVZmjr235jVh/NHMPa791ymNE=; b=Ft/dtsQy4TfpdFd0Q7WiZLeqmj JcbzzSReg13ya9ZpwtvZoVz/vgTZ0ZPUuDrBSE/JKW7jsbzvmqvQFgHyb0IjZz3HLVkSfev+cqKga m1W+Z2vzSYISFojiFuj9Gg599Bdi9p5xQTUBkGBIZWzU2X6J24ZRk1sbkv2x7ac04HXZwimWviduo A2RUf1nfV8FbiV/7k/5TfFyALkFxEtIdqlx9Of27zthuFuq54Je67BUwtR9wv7lbMhOfExcpAQ8GP vNbn1aLnr8pIPcTX4XSCYvFLu7yfVdLxHcodNL1ED+AR98MqUIyu8C5a4hD34SiuK7C7S9jdGNzI7 0OL3UcjA==; Received: from [38.44.68.151] (helo=mail.igalia.com) by fanzine2.igalia.com with esmtpsa (Cipher TLS1.3:ECDHE_SECP256R1__RSA_PSS_RSAE_SHA256__AES_256_GCM:256) (Exim) id 1qeco0-001PYn-24; Fri, 08 Sep 2023 16:49:55 +0200 Date: Fri, 8 Sep 2023 13:49:47 -0100 From: Melissa Wen To: Harry Wentland Cc: amd-gfx@lists.freedesktop.org, Rodrigo Siqueira , sunpeng.li@amd.com, Alex Deucher , dri-devel@lists.freedesktop.org, christian.koenig@amd.com, Xinhui.Pan@amd.com, airlied@gmail.com, daniel@ffwll.ch, Joshua Ashton , Sebastian Wick , Xaver Hugl , Shashank Sharma , Nicholas Kazlauskas , sungjoon.kim@amd.com, Alex Hung , Pekka Paalanen , Simon Ser , kernel-dev@igalia.com, linux-kernel@vger.kernel.org Subject: Re: [PATCH v2 33/34] drm/amd/display: add plane CTM support Message-ID: <20230908144947.ih5z4x6wol2mcrod@mail.igalia.com> References: <20230810160314.48225-1-mwen@igalia.com> <20230810160314.48225-34-mwen@igalia.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_NONE,SPF_PASS 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 On 09/06, Harry Wentland wrote: > > > On 2023-08-10 12:03, Melissa Wen wrote: > > Map the plane CTM driver-specific property to DC plane, instead of DC > > stream. The remaining steps to program DPP block are already implemented > > on DC shared-code. > > > > Signed-off-by: Melissa Wen > > --- > > .../gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c | 1 + > > .../amd/display/amdgpu_dm/amdgpu_dm_color.c | 25 +++++++++++++++++++ > > 2 files changed, 26 insertions(+) > > > > diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c > > index dfe61c5ed49e..f239410234b3 100644 > > --- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c > > +++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c > > @@ -9578,6 +9578,7 @@ static bool should_reset_plane(struct drm_atomic_state *state, > > if (dm_old_other_state->degamma_tf != dm_new_other_state->degamma_tf || > > dm_old_other_state->degamma_lut != dm_new_other_state->degamma_lut || > > dm_old_other_state->hdr_mult != dm_new_other_state->hdr_mult || > > + dm_old_other_state->ctm != dm_new_other_state->ctm || > > dm_old_other_state->shaper_lut != dm_new_other_state->shaper_lut || > > dm_old_other_state->shaper_tf != dm_new_other_state->shaper_tf || > > dm_old_other_state->lut3d != dm_new_other_state->lut3d || > > diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_color.c b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_color.c > > index 86a918ab82be..7ff329101fd4 100644 > > --- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_color.c > > +++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_color.c > > @@ -1158,6 +1158,8 @@ int amdgpu_dm_update_plane_color_mgmt(struct dm_crtc_state *crtc, > > struct dc_plane_state *dc_plane_state) > > { > > struct amdgpu_device *adev = drm_to_adev(crtc->base.state->dev); > > + struct dm_plane_state *dm_plane_state = to_dm_plane_state(plane_state); > > + struct drm_color_ctm *ctm = NULL; > > struct dc_color_caps *color_caps = NULL; > > bool has_crtc_cm_degamma; > > int ret; > > @@ -1209,6 +1211,29 @@ int amdgpu_dm_update_plane_color_mgmt(struct dm_crtc_state *crtc, > > return ret; > > } > > > > + /* Setup CRTC CTM. */ > > + if (dm_plane_state->ctm) { > > + ctm = (struct drm_color_ctm *)dm_plane_state->ctm->data; > > + > > + /* > > + * So far, if we have both plane and CRTC CTM, plane CTM takes > > + * the priority and we discard data for CRTC CTM, as > > + * implemented in dcn10_program_gamut_remap(). However, we > > Isn't it the opposite? If stream (crtc) has a CTM we program that, only if > stream doesn't have a CTM we program the plane one? yeah, you're right. It was an intermediate approach that was discarded. Indeed, I think I need to rewrite it to better describe that CRTC CTM priority regarding DPP gamut remap matrix. Thanks for pointing it out. Melissa > > Harry > > > + * have MPC gamut_remap_matrix from DCN3 family, therefore we > > + * can remap MPC programing of the matrix to MPC block and > > + * provide support for both DPP and MPC matrix at the same > > + * time. > > + */ > > + __drm_ctm_to_dc_matrix(ctm, dc_plane_state->gamut_remap_matrix.matrix); > > + > > + dc_plane_state->gamut_remap_matrix.enable_remap = true; > > + dc_plane_state->input_csc_color_matrix.enable_adjustment = false; > > + } else { > > + /* Bypass CTM. */ > > + dc_plane_state->gamut_remap_matrix.enable_remap = false; > > + dc_plane_state->input_csc_color_matrix.enable_adjustment = false; > > + } > > + > > return amdgpu_dm_plane_set_color_properties(plane_state, > > dc_plane_state, color_caps); > > } >