Received: by 2002:a05:7412:85a1:b0:e2:908c:2ebd with SMTP id n33csp27565rdh; Mon, 30 Oct 2023 12:39:56 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEmj7OyobO8x+YcFOIRwmPuCubt+4n8wPYiCl5yzxZa+2PMmGS0N/JfsP5gnf/YbfqZaz8C X-Received: by 2002:a17:90a:7525:b0:27d:2d02:ab14 with SMTP id q34-20020a17090a752500b0027d2d02ab14mr9139646pjk.18.1698694796207; Mon, 30 Oct 2023 12:39:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698694796; cv=none; d=google.com; s=arc-20160816; b=C8sMTXZCdQDOVkR7VtU7F6Od/452FiX/u5rjflO14nIxtKSeez9ONibrHqOFpRaymG QwjJrLHkLyGgd7HlmSbNUEFNCenFH70ZJ6L3NdDMDYjowkrT36Msom2hcl6weQ7w2SCE E+iwhut9ftYkEpMjRPcaXuJD3CnfzItAsXZTTAYXV6id+OR8QlGKAKnfdwL562IP+GC7 eJJSc18eGgJ20wzV5SIJzUPmhpBE1My8GQ9HWdHUqjx1h8lZElqlfuhhX21DerjiOAdf 8x2cJ+E4XVcOT7XpCPLFL04MTqiBInUYwhRJn0GKYoUZhHrpYwH/DTmq9n7dZWpuz5Gc xuPQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=eRZhcwsh01MNRG8TzbgicpmIGpJj8SD8iJ7MpzFDb5s=; fh=ufBMDIyS5iECrN3KwJuexmz7dT3gbz5E5L208DIb1ZA=; b=Iq0FeLW337sCoqmuwXGEaf2pBIxDb5j/U4D6HIsAveFwi2fnqDWX/yDTY5/RoQyDPK WXt95xSaPvC9h1ggxFdQNfXBujbhwDCEWiMXGBZziYFjXizG/wLmLdIq/J1Ib6azeTiT FQ5ly/QeJJxXgQDXeFaO2qfWGWtV6Ohg3Y2cHxex7U473udORJ3GpyX1O4eLSMSGuAfh BrGdRBraJe2K3FMBp3wd1+42cmYdew0F60u/x83TibCNBujT8IW0GYPZOfbBIXhQZzTY WH4KS1PBFmlTwIrD9t/a/HCUsDOl7nGCRLCQdlmnLFIEpewwkqqO37hs2eJV5jlKaeKY b0NQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=Bgznk0m8; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from pete.vger.email (pete.vger.email. [2620:137:e000::3:6]) by mx.google.com with ESMTPS id s91-20020a17090a69e400b0026b51ae4574si4167229pjj.36.2023.10.30.12.39.55 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 30 Oct 2023 12:39:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) client-ip=2620:137:e000::3:6; Authentication-Results: mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=Bgznk0m8; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by pete.vger.email (Postfix) with ESMTP id 51B80807E452; Mon, 30 Oct 2023 12:39:52 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at pete.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231635AbjJ3Tji (ORCPT + 99 others); Mon, 30 Oct 2023 15:39:38 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50774 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230299AbjJ3Tjh (ORCPT ); Mon, 30 Oct 2023 15:39:37 -0400 Received: from lelv0143.ext.ti.com (lelv0143.ext.ti.com [198.47.23.248]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 670FEB3 for ; Mon, 30 Oct 2023 12:39:34 -0700 (PDT) Received: from lelv0266.itg.ti.com ([10.180.67.225]) by lelv0143.ext.ti.com (8.15.2/8.15.2) with ESMTP id 39UJcr0l063551; Mon, 30 Oct 2023 14:38:53 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1698694733; bh=eRZhcwsh01MNRG8TzbgicpmIGpJj8SD8iJ7MpzFDb5s=; h=Date:Subject:To:CC:References:From:In-Reply-To; b=Bgznk0m8c8vaPJxAyhJ73LdxsvpephUr9tog/J5DHUeZBeEqqD0y5axcihHlCAP23 Ulo2kIB8YBLEl5IA7x6+mnbtL+XfEYVMc/6GdEiCpCIHC1vkD1w+rvlCaakPI3jZNS h7Rzt3k0JCQqJl5angST+WT7hnLLxGWAbbnOBzmI= Received: from DLEE106.ent.ti.com (dlee106.ent.ti.com [157.170.170.36]) by lelv0266.itg.ti.com (8.15.2/8.15.2) with ESMTPS id 39UJcraB008524 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Mon, 30 Oct 2023 14:38:53 -0500 Received: from DLEE114.ent.ti.com (157.170.170.25) by DLEE106.ent.ti.com (157.170.170.36) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2507.23; Mon, 30 Oct 2023 14:38:52 -0500 Received: from fllv0039.itg.ti.com (10.64.41.19) by DLEE114.ent.ti.com (157.170.170.25) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2507.23 via Frontend Transport; Mon, 30 Oct 2023 14:38:52 -0500 Received: from [10.249.132.69] (ileaxei01-snat2.itg.ti.com [10.180.69.6]) by fllv0039.itg.ti.com (8.15.2/8.15.2) with ESMTP id 39UJchRe002093; Mon, 30 Oct 2023 14:38:45 -0500 Message-ID: Date: Tue, 31 Oct 2023 01:08:43 +0530 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.15.1 Subject: Re: [PATCH v7 7/8] drm/tidss: Update encoder/bridge chain connect model Content-Language: en-US To: Jan Kiszka , Tomi Valkeinen , Jyri Sarha , David Airlie , Daniel Vetter , Laurent Pinchart , Andrzej Hajda , Neil Armstrong , Robert Foss , Jonas Karlman , Jernej Skrabec , Swapnil Jakhade , Boris Brezillon , Francesco Dolcini CC: DRI Development List , Linux Kernel List , Nishanth Menon , Vignesh Raghavendra , Rahul T R , Devarsh Thakkar , Jayesh Choudhary , "Su, Bao Cheng (RC-CN DF FA R&D)" References: <20230606082142.23760-1-a-bhatia1@ti.com> <20230606082142.23760-8-a-bhatia1@ti.com> <24282420-b4dd-45b3-bb1c-fc37fe4a8205@siemens.com> From: Aradhya Bhatia In-Reply-To: <24282420-b4dd-45b3-bb1c-fc37fe4a8205@siemens.com> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 X-Spam-Status: No, score=-5.8 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on pete.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (pete.vger.email [0.0.0.0]); Mon, 30 Oct 2023 12:39:52 -0700 (PDT) On 30-Oct-23 14:55, Jan Kiszka wrote: > On 06.06.23 10:21, Aradhya Bhatia wrote: >> With the new encoder/bridge chain model, the display controller driver >> is required to create a drm_connector entity instead of asking the >> bridge to do so during drm_bridge_attach. Moreover, the controller >> driver should create a drm_bridge entity to negotiate bus formats and a >> 'simple' drm_encoder entity to expose it to userspace. >> >> Update the encoder/bridge initialization sequence in tidss as per the >> new model. >> >> Signed-off-by: Aradhya Bhatia >> --- >> >> Notes: >> >> changes from v5: >> * Drop patches 5 and 6 from the original series. >> * Instead add this patch that addresses Boris Brezillon's comments >> of creating bridge, simple encoder and connector. >> >> drivers/gpu/drm/tidss/tidss_encoder.c | 140 ++++++++++++++++---------- >> drivers/gpu/drm/tidss/tidss_encoder.h | 5 +- >> drivers/gpu/drm/tidss/tidss_kms.c | 12 +-- >> 3 files changed, 94 insertions(+), 63 deletions(-) >> >> diff --git a/drivers/gpu/drm/tidss/tidss_encoder.c b/drivers/gpu/drm/tidss/tidss_encoder.c >> index 0d4865e9c03d..17a86bed8054 100644 >> --- a/drivers/gpu/drm/tidss/tidss_encoder.c >> +++ b/drivers/gpu/drm/tidss/tidss_encoder.c >> @@ -6,91 +6,125 @@ >> >> #include >> >> +#include >> +#include >> +#include >> #include >> #include >> #include >> #include >> +#include >> >> #include "tidss_crtc.h" >> #include "tidss_drv.h" >> #include "tidss_encoder.h" >> >> -static int tidss_encoder_atomic_check(struct drm_encoder *encoder, >> - struct drm_crtc_state *crtc_state, >> - struct drm_connector_state *conn_state) >> +struct tidss_encoder { >> + struct drm_bridge bridge; >> + struct drm_encoder encoder; >> + struct drm_connector *connector; >> + struct drm_bridge *next_bridge; >> + struct tidss_device *tidss; >> +}; >> + >> +static inline struct tidss_encoder >> +*bridge_to_tidss_encoder(struct drm_bridge *b) >> +{ >> + return container_of(b, struct tidss_encoder, bridge); >> +} >> + >> +static int tidss_bridge_attach(struct drm_bridge *bridge, >> + enum drm_bridge_attach_flags flags) >> +{ >> + struct tidss_encoder *t_enc = bridge_to_tidss_encoder(bridge); >> + >> + return drm_bridge_attach(bridge->encoder, t_enc->next_bridge, >> + bridge, flags); >> +} >> + >> +static int tidss_bridge_atomic_check(struct drm_bridge *bridge, >> + struct drm_bridge_state *bridge_state, >> + struct drm_crtc_state *crtc_state, >> + struct drm_connector_state *conn_state) >> { >> - struct drm_device *ddev = encoder->dev; >> + struct tidss_encoder *t_enc = bridge_to_tidss_encoder(bridge); >> + struct tidss_device *tidss = t_enc->tidss; >> struct tidss_crtc_state *tcrtc_state = to_tidss_crtc_state(crtc_state); >> struct drm_display_info *di = &conn_state->connector->display_info; >> - struct drm_bridge *bridge; >> - bool bus_flags_set = false; >> - >> - dev_dbg(ddev->dev, "%s\n", __func__); >> - >> - /* >> - * Take the bus_flags from the first bridge that defines >> - * bridge timings, or from the connector's display_info if no >> - * bridge defines the timings. >> - */ >> - drm_for_each_bridge_in_chain(encoder, bridge) { >> - if (!bridge->timings) >> - continue; >> - >> - tcrtc_state->bus_flags = bridge->timings->input_bus_flags; >> - bus_flags_set = true; >> - break; >> - } >> + struct drm_bridge_state *next_bridge_state = NULL; >> + >> + if (t_enc->next_bridge) >> + next_bridge_state = drm_atomic_get_new_bridge_state(crtc_state->state, >> + t_enc->next_bridge); >> >> - if (!di->bus_formats || di->num_bus_formats == 0) { >> - dev_err(ddev->dev, "%s: No bus_formats in connected display\n", >> + if (next_bridge_state) { >> + tcrtc_state->bus_flags = next_bridge_state->input_bus_cfg.flags; >> + tcrtc_state->bus_format = next_bridge_state->input_bus_cfg.format; >> + } else if (di->num_bus_formats) { >> + tcrtc_state->bus_format = di->bus_formats[0]; >> + tcrtc_state->bus_flags = di->bus_flags; >> + } else { >> + dev_err(tidss->dev, "%s: No bus_formats in connected display\n", >> __func__); >> return -EINVAL; >> } >> >> - // XXX any cleaner way to set bus format and flags? >> - tcrtc_state->bus_format = di->bus_formats[0]; >> - if (!bus_flags_set) >> - tcrtc_state->bus_flags = di->bus_flags; >> - >> return 0; >> } >> >> -static void tidss_encoder_destroy(struct drm_encoder *encoder) >> -{ >> - drm_encoder_cleanup(encoder); >> - kfree(encoder); >> -} >> - >> -static const struct drm_encoder_helper_funcs encoder_helper_funcs = { >> - .atomic_check = tidss_encoder_atomic_check, >> -}; >> - >> -static const struct drm_encoder_funcs encoder_funcs = { >> - .destroy = tidss_encoder_destroy, >> +static const struct drm_bridge_funcs tidss_bridge_funcs = { >> + .attach = tidss_bridge_attach, >> + .atomic_check = tidss_bridge_atomic_check, >> + .atomic_reset = drm_atomic_helper_bridge_reset, >> + .atomic_duplicate_state = drm_atomic_helper_bridge_duplicate_state, >> + .atomic_destroy_state = drm_atomic_helper_bridge_destroy_state, >> }; >> >> -struct drm_encoder *tidss_encoder_create(struct tidss_device *tidss, >> - u32 encoder_type, u32 possible_crtcs) >> +int tidss_encoder_create(struct tidss_device *tidss, >> + struct drm_bridge *next_bridge, >> + u32 encoder_type, u32 possible_crtcs) >> { >> + struct tidss_encoder *t_enc; >> struct drm_encoder *enc; >> + struct drm_connector *connector; >> int ret; >> >> - enc = kzalloc(sizeof(*enc), GFP_KERNEL); >> - if (!enc) >> - return ERR_PTR(-ENOMEM); >> + t_enc = drmm_simple_encoder_alloc(&tidss->ddev, struct tidss_encoder, >> + encoder, encoder_type); >> + if (IS_ERR(t_enc)) >> + return PTR_ERR(t_enc); >> + >> + t_enc->tidss = tidss; >> + t_enc->next_bridge = next_bridge; >> + t_enc->bridge.funcs = &tidss_bridge_funcs; >> >> + enc = &t_enc->encoder; >> enc->possible_crtcs = possible_crtcs; >> >> - ret = drm_encoder_init(&tidss->ddev, enc, &encoder_funcs, >> - encoder_type, NULL); >> - if (ret < 0) { >> - kfree(enc); >> - return ERR_PTR(ret); >> + /* Attaching first bridge to the encoder */ >> + ret = drm_bridge_attach(enc, &t_enc->bridge, NULL, >> + DRM_BRIDGE_ATTACH_NO_CONNECTOR); >> + if (ret) { >> + dev_err(tidss->dev, "bridge attach failed: %d\n", ret); >> + return ret; >> + } >> + >> + /* Initializing the connector at the end of bridge-chain */ >> + connector = drm_bridge_connector_init(&tidss->ddev, enc); >> + if (IS_ERR(connector)) { >> + dev_err(tidss->dev, "bridge_connector create failed\n"); >> + return PTR_ERR(connector); >> + } >> + >> + ret = drm_connector_attach_encoder(connector, enc); >> + if (ret) { >> + dev_err(tidss->dev, "attaching encoder to connector failed\n"); >> + return ret; >> } >> >> - drm_encoder_helper_add(enc, &encoder_helper_funcs); >> + t_enc->connector = connector; >> >> dev_dbg(tidss->dev, "Encoder create done\n"); >> >> - return enc; >> + return ret; >> } >> diff --git a/drivers/gpu/drm/tidss/tidss_encoder.h b/drivers/gpu/drm/tidss/tidss_encoder.h >> index ace877c0e0fd..3e561d6b1e83 100644 >> --- a/drivers/gpu/drm/tidss/tidss_encoder.h >> +++ b/drivers/gpu/drm/tidss/tidss_encoder.h >> @@ -11,7 +11,8 @@ >> >> struct tidss_device; >> >> -struct drm_encoder *tidss_encoder_create(struct tidss_device *tidss, >> - u32 encoder_type, u32 possible_crtcs); >> +int tidss_encoder_create(struct tidss_device *tidss, >> + struct drm_bridge *next_bridge, >> + u32 encoder_type, u32 possible_crtcs); >> >> #endif >> diff --git a/drivers/gpu/drm/tidss/tidss_kms.c b/drivers/gpu/drm/tidss/tidss_kms.c >> index ad2fa3c3d4a7..c979ad1af236 100644 >> --- a/drivers/gpu/drm/tidss/tidss_kms.c >> +++ b/drivers/gpu/drm/tidss/tidss_kms.c >> @@ -193,7 +193,6 @@ static int tidss_dispc_modeset_init(struct tidss_device *tidss) >> for (i = 0; i < num_pipes; ++i) { >> struct tidss_plane *tplane; >> struct tidss_crtc *tcrtc; >> - struct drm_encoder *enc; >> u32 hw_plane_id = feat->vid_order[tidss->num_planes]; >> int ret; >> >> @@ -216,16 +215,13 @@ static int tidss_dispc_modeset_init(struct tidss_device *tidss) >> >> tidss->crtcs[tidss->num_crtcs++] = &tcrtc->crtc; >> >> - enc = tidss_encoder_create(tidss, pipes[i].enc_type, >> + ret = tidss_encoder_create(tidss, pipes[i].bridge, >> + pipes[i].enc_type, >> 1 << tcrtc->crtc.index); >> - if (IS_ERR(enc)) { >> + if (ret) { >> dev_err(tidss->dev, "encoder create failed\n"); >> - return PTR_ERR(enc); >> - } >> - >> - ret = drm_bridge_attach(enc, pipes[i].bridge, NULL, 0); >> - if (ret) >> return ret; >> + } >> } >> >> /* create overlay planes of the leftover planes */ > > This breaks the IOT2050 devices over 6.6, just bisected to it: > > [ 3.435153] [drm] Initialized tidss 1.0.0 20180215 for 4a00000.dss on minor 0 > [ 3.491246] tidss 4a00000.dss: [drm] Cannot find any crtc or sizes > > vs. > > [ 3.436116] [drm] Initialized tidss 1.0.0 20180215 for 4a00000.dss on minor 0 > [ 3.910574] Console: switching to colour frame buffer device 80x30 > [ 3.937614] tidss 4a00000.dss: [drm] fb0: tidssdrmfb frame buffer device > > Do we need to adjust its device tree to anything, or what may be the > reason? > Hey Jan, This patch series added support for the DRM_BRIDGE_ATTACH_NO_CONNECTOR flag, for tidss, and for a few of the bridges. Upon a quick look at the devicetree files, I see that the IOT-2050 platform is using Toshiba's TC358767 DPI to DP bridge, and it appears that the TC358767 driver does not support the get_input_bus_fmt hook. I have sent a patch for it[0]. Since I do not have hardware with me, I would appreciate it if you could test and review it. The patch has only been build tested. Regards Aradhya [0]: Patch Link: https://lore.kernel.org/all/20231030192846.27934-1-a-bhatia1@ti.com/