Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp4719632pxb; Tue, 28 Sep 2021 02:30:36 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwCz2kvQQpwApSjHAvlIDHvrrz0VV2nWee82CCM7RKHGcdmIsGrINdJF/pQ7LSu3SF7RIVx X-Received: by 2002:a63:34c5:: with SMTP id b188mr3778033pga.133.1632821435941; Tue, 28 Sep 2021 02:30:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1632821435; cv=none; d=google.com; s=arc-20160816; b=lB/OTQnO2riDGZXUrWttkB0JUGh8cDsjxIbulRcIzL3zL3N1ylu7wFDD3Lt/RIRtGP Wc/Tj15HIGM1dHZjmljJqAo/E+wO0KpDMaZULxOuJIywSnwJ0ubxXF+Fja4i/F7gDuZI 3fTQzvUIkgjxBF4qzOB8xg+CWHxwa5/LcKSzOJ5i7sj44h7uNETgopo3LalpnujGEZMm m8rrZP/Uz8Wtc8CebV0Aqabz4yOhXXfTCRtuXtENut+vZmz58rgK1CSoLF7CTqhIJck7 J5FYQPcRgl+qqHl0BuY5haVG0zw3eieJDq0KqObH0FcR/xADk4HBSa1N5jcSRC00lP8h wF3Q== 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-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature:dkim-signature; bh=vFTIQRLZr/dArPvWWyWXOtO3bm56Qd7mD1aEXj7fSF4=; b=pYAExjCVT53JHpb+8KMmUf37bqMXK/EAMvcnPjM8uCkqR/BJIBP1iERtUIHFVDHneD 3+RNCZVym401vKD3Z1/r3IAaQtgLu6c5laja74Ke+vlvpHyNFWg5Dphh0xxg8x8ewAa4 KkPAvrftNS7X4aK1E6rTCVMsCSJcdhM6LxnzohIEa8BZkYdasc6BPXhwpTsKs1cnMsYn JGqsTg0m+Kb4H8EG0PTfBVBPcnKwJvktRso8uU0QN3HD5u765N+bgW9rcT50LFyqF1Uu TYcLe0PLvMjw+/S8n1ubkAeMwubzoARF8Ic0SdydHWOAF4QI1zPZKVv6jvNNsT7Uzjpm 7UGA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cerno.tech header.s=fm1 header.b=A+e0TYhH; dkim=pass header.i=@messagingengine.com header.s=fm3 header.b=DdUqr9mZ; 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=cerno.tech Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y5si29755430pgk.321.2021.09.28.02.30.05; Tue, 28 Sep 2021 02:30:35 -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=@cerno.tech header.s=fm1 header.b=A+e0TYhH; dkim=pass header.i=@messagingengine.com header.s=fm3 header.b=DdUqr9mZ; 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=cerno.tech Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239942AbhI1J3w (ORCPT + 99 others); Tue, 28 Sep 2021 05:29:52 -0400 Received: from new1-smtp.messagingengine.com ([66.111.4.221]:54727 "EHLO new1-smtp.messagingengine.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239941AbhI1J3r (ORCPT ); Tue, 28 Sep 2021 05:29:47 -0400 Received: from compute4.internal (compute4.nyi.internal [10.202.2.44]) by mailnew.nyi.internal (Postfix) with ESMTP id 575E8580743; Tue, 28 Sep 2021 05:28:08 -0400 (EDT) Received: from mailfrontend1 ([10.202.2.162]) by compute4.internal (MEProxy); Tue, 28 Sep 2021 05:28:08 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cerno.tech; h= date:from:to:cc:subject:message-id:references:mime-version :content-type:content-transfer-encoding:in-reply-to; s=fm1; bh=v FTIQRLZr/dArPvWWyWXOtO3bm56Qd7mD1aEXj7fSF4=; b=A+e0TYhHh0znYGJ3e 2mpCX1lsbgqMC/T9SMPn/wYORa7svwJEHQ756WW3uTpLBuAYAUdBgQv4cN/EGwGO LQL42aQVJiukHgIgBybulyVVxrHMEz5tLxOhblrtN/HAMcu1W6B+WAPnuESRCLSd eWEUxs1JDaN1b5QzCIqKGz8gXs6VR3n+yRZ/gdJPCcBR5pOjDFVXfdAdB4tvZi4x 5ixGiZK3eDS3Gc0YnEl7t4FJ1jcVDHaMok/+rkHvn/THpOwV1cbeGZPJSw6vhuZD OprRqRWgiqoPZzJWyoaRCq5OPm5fVLDEjV+4jmxj16GGkTUf6biZS0+qKyGCMJv4 ciLAQ== DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d= messagingengine.com; h=cc:content-transfer-encoding:content-type :date:from:in-reply-to:message-id:mime-version:references :subject:to:x-me-proxy:x-me-proxy:x-me-sender:x-me-sender :x-sasl-enc; s=fm3; bh=vFTIQRLZr/dArPvWWyWXOtO3bm56Qd7mD1aEXj7fS F4=; b=DdUqr9mZUoVwDCQaWDk7IqdJVHvBwLIjLg7Ptj/vwWvORiACaisq8YlXA dIlGynkivXO6BO44HIF4nKmPT5V/C0H0AwSgcFEXNoai2Ts0Tj5DiXzHin6T5OlG jPW6hvJSJT5hV+i4rGbRrcjfWUfLxkTGYA5ZjYB8IVojFdRDNgj0QgQJM0i9Kr5O vaXielntuNHjKGM0cwG+XaWd9Rzfebyyq5lfZj4fXW6sIyZAY7TUq+2iAEfuCD9W 5PwGRO4EdAA6m1YNpQ0EzJtBf+1vJYrBv7fQGr0Cp9IXc/TEGUptDHhycenY0PYU BEQp9GJn7AARa8M49fu0gz6lx/4sg== X-ME-Sender: X-ME-Received: X-ME-Proxy-Cause: gggruggvucftvghtrhhoucdtuddrgedvtddrudektddguddvucetufdoteggodetrfdotf fvucfrrhhofhhilhgvmecuhfgrshhtofgrihhlpdfqfgfvpdfurfetoffkrfgpnffqhgen uceurghilhhouhhtmecufedttdenucesvcftvggtihhpihgvnhhtshculddquddttddmne cujfgurhepfffhvffukfhfgggtugfgjgesthhqredttddtjeenucfhrhhomhepofgrgihi mhgvucftihhprghrugcuoehmrgigihhmvgestggvrhhnohdrthgvtghhqeenucggtffrrg htthgvrhhnpefhueeggfdvieegjeeigeffudeuhfeuveeuieelgfffleelgedtiefgvdev ieevvdenucffohhmrghinhepkhgvrhhnvghlrdhorhhgnecuvehluhhsthgvrhfuihiivg eptdenucfrrghrrghmpehmrghilhhfrhhomhepmhgrgihimhgvsegtvghrnhhordhtvggt hh X-ME-Proxy: Received: by mail.messagingengine.com (Postfix) with ESMTPA; Tue, 28 Sep 2021 05:28:07 -0400 (EDT) Date: Tue, 28 Sep 2021 11:28:05 +0200 From: Maxime Ripard To: Kevin Tang Cc: Maarten Lankhorst , Sean Paul , David Airlie , Daniel Vetter , Rob Herring , Mark Rutland , pony1.wu@gmail.com, Orson Zhai , Chunyan Zhang , "Linux-Kernel@Vger. Kernel. Org" , ML dri-devel , devicetree@vger.kernel.org Subject: Re: [PATCH v6 6/6] drm/sprd: add Unisoc's drm mipi dsi&dphy driver Message-ID: <20210928092805.wbc4ev3ze7a7zgqr@gilmour> References: <20210813145302.3933-1-kevin3.tang@gmail.com> <20210813145302.3933-7-kevin3.tang@gmail.com> <20210917154047.leojvqjqjj2sg34l@gilmour> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: quoted-printable In-Reply-To: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Sep 26, 2021 at 10:31:53PM +0800, Kevin Tang wrote: > Maxime Ripard =E4=BA=8E2021=E5=B9=B49=E6=9C=8817=E6= =97=A5=E5=91=A8=E4=BA=94 =E4=B8=8B=E5=8D=8811:40=E5=86=99=E9=81=93=EF=BC=9A > > > +static void sprd_dsi_encoder_mode_set(struct drm_encoder *encoder, > > > + struct drm_display_mode *mode, > > > + struct drm_display_mode *adj_mode) > > > +{ > > > + struct sprd_dsi *dsi =3D encoder_to_dsi(encoder); > > > + > > > + drm_dbg(dsi->drm, "%s() set mode: %s\n", __func__, dsi->mode->n= ame); > > > +} > > > > You don't need that function? > No need for now. need to delete it? Yes > > > +static int sprd_dsi_encoder_atomic_check(struct drm_encoder *encoder, > > > + struct drm_crtc_state *crtc_state, > > > + struct drm_connector_state *conn_st= ate) > > > +{ > > > + return 0; > > > +} > > > > Ditto > > No need for now. need to delete it? Yep > > > +static int sprd_dsi_find_panel(struct sprd_dsi *dsi) > > > +{ > > > + struct device *dev =3D dsi->host.dev; > > > + struct device_node *child, *lcds_node; > > > + struct drm_panel *panel; > > > + > > > + /* search /lcds child node first */ > > > + lcds_node =3D of_find_node_by_path("/lcds"); > > > + for_each_child_of_node(lcds_node, child) { > > > + panel =3D of_drm_find_panel(child); > > > + if (!IS_ERR(panel)) { > > > + dsi->panel =3D panel; > > > + return 0; > > > + } > > > + } > > > + > > > + /* > > > + * If /lcds child node search failed, we search > > > + * the child of dsi host node. > > > + */ > > > + for_each_child_of_node(dev->of_node, child) { > > > + panel =3D of_drm_find_panel(child); > > > + if (!IS_ERR(panel)) { > > > + dsi->panel =3D panel; > > > + return 0; > > > + } > > > + } > > > + > > > + drm_err(dsi->drm, "of_drm_find_panel() failed\n"); > > > + return -ENODEV; > > > +} > > > > Just use devm_drm_of_get_bridge there > > We use drm_panel_init and drm_panel_add API to add panel, so here is a > panel device, not a bridge. Like Sam said, the panel API is on its way out and is being superseded by bridge_panels. > > > +static int sprd_dsi_host_init(struct sprd_dsi *dsi, struct device *d= ev) > > > +{ > > > + int ret; > > > + > > > + dsi->host.dev =3D dev; > > > + dsi->host.ops =3D &sprd_dsi_host_ops; > > > + > > > + ret =3D mipi_dsi_host_register(&dsi->host); > > > + if (ret) > > > + drm_err(dsi->drm, "failed to register dsi host\n"); > > > + > > > + return ret; > > > +} > > > > > > [...] > > > > > > +static int sprd_dsi_connector_init(struct drm_device *drm, struct sp= rd_dsi *dsi) > > > +{ > > > + struct drm_encoder *encoder =3D &dsi->encoder; > > > + struct drm_connector *connector =3D &dsi->connector; > > > + int ret; > > > + > > > + connector->polled =3D DRM_CONNECTOR_POLL_HPD; > > > + > > > + ret =3D drm_connector_init(drm, connector, > > > + &sprd_dsi_atomic_connector_funcs, > > > + DRM_MODE_CONNECTOR_DSI); > > > + if (ret) { > > > + drm_err(drm, "drm_connector_init() failed\n"); > > > + return ret; > > > + } > > > + > > > + drm_connector_helper_add(connector, > > > + &sprd_dsi_connector_helper_funcs); > > > + > > > + drm_connector_attach_encoder(connector, encoder); > > > + > > > + return 0; > > > +} > > > + > > > +static int sprd_dsi_context_init(struct sprd_dsi *dsi, > > > + struct device *dev) > > > +{ > > > + struct platform_device *pdev =3D to_platform_device(dev); > > > + struct dsi_context *ctx =3D &dsi->ctx; > > > + struct resource *res; > > > + > > > + res =3D platform_get_resource(pdev, IORESOURCE_MEM, 0); > > > + ctx->base =3D devm_ioremap(dev, res->start, resource_size(res)); > > > + if (!ctx->base) { > > > + drm_err(dsi->drm, "failed to map dsi host registers\n"); > > > + return -ENXIO; > > > + } > > > + > > > + ctx->pll =3D devm_kzalloc(dev, sizeof(*ctx->pll), GFP_KERNEL); > > > + if (!ctx->pll) > > > + return -ENOMEM; > > > + > > > + ctx->regmap =3D devm_regmap_init(dev, ®map_tst_io, dsi, &byt= e_config); > > > + if (IS_ERR(ctx->regmap)) { > > > + drm_err(dsi->drm, "dphy regmap init failed\n"); > > > + return PTR_ERR(ctx->regmap); > > > + } > > > + > > > + ctx->data_hs2lp =3D 120; > > > + ctx->data_lp2hs =3D 500; > > > + ctx->clk_hs2lp =3D 4; > > > + ctx->clk_lp2hs =3D 15; > > > + ctx->max_rd_time =3D 6000; > > > + ctx->int0_mask =3D 0xffffffff; > > > + ctx->int1_mask =3D 0xffffffff; > > > + ctx->enabled =3D true; > > > + > > > + return 0; > > > +} > > > + > > > +static int sprd_dsi_bind(struct device *dev, struct device *master, = void *data) > > > +{ > > > + struct drm_device *drm =3D data; > > > + struct sprd_dsi *dsi; > > > + int ret; > > > + > > > + dsi =3D sprd_dsi_encoder_init(drm, dev); > > > + if (IS_ERR(dsi)) > > > + return PTR_ERR(dsi); > > > + > > > + dsi->drm =3D drm; > > > + dev_set_drvdata(dev, dsi); > > > + > > > + ret =3D sprd_dsi_connector_init(drm, dsi); > > > + if (ret) > > > + return ret; > > > + > > > + ret =3D sprd_dsi_context_init(dsi, dev); > > > + if (ret) > > > + return ret; > > > + > > > + ret =3D sprd_dsi_host_init(dsi, dev); > > > + if (ret) > > > + return ret; > > > + > > > + return 0; > > > +} > > > + > > > +static void sprd_dsi_unbind(struct device *dev, > > > + struct device *master, void *data) > > > +{ > > > + struct sprd_dsi *dsi =3D dev_get_drvdata(dev); > > > + > > > + mipi_dsi_host_unregister(&dsi->host); > > > +} > > > + > > > +static const struct component_ops dsi_component_ops =3D { > > > + .bind =3D sprd_dsi_bind, > > > + .unbind =3D sprd_dsi_unbind, > > > +}; > > > + > > > +static const struct of_device_id dsi_match_table[] =3D { > > > + { .compatible =3D "sprd,sharkl3-dsi-host" }, > > > + { /* sentinel */ }, > > > +}; > > > + > > > +static int sprd_dsi_probe(struct platform_device *pdev) > > > +{ > > > + return component_add(&pdev->dev, &dsi_component_ops); > > > > In order to prevent probe issues, you need to register you mipi_dsi_host > > here, see: > > https://lore.kernel.org/dri-devel/20210910101218.1632297-3-maxime@cerno= =2Etech/ > > We register mipi_dsi_hot on our panel driver, like this: >=20 > 1092 ret =3D mipi_dsi_attach(slave); > 1093 if (ret) { > 1094 DRM_ERROR("failed to attach dsi panel to host\n"); > 1095 drm_panel_remove(&panel->base); > 1096 return ret; > 1097 } It's not about when you attach, but when you call mipi_dsi_host_register. You're doing it in sprd_dsi_host_init that you call in bind(), which is against the best practices and will create probing issues in the future. Maxime