From: Inki Dae <inki.dae@samsung.com>
To: Andrzej Hajda <a.hajda@samsung.com>, dri-devel@lists.freedesktop.org
Cc: linux-samsung-soc@vger.kernel.org, Shuah Khan <shuahkh@osg.samsung.com>
Subject: Re: [PATCH 1/2] drm/exynos: dsi: move of_drm_find_bridge call into probe
Date: Tue, 04 Jul 2017 07:42:47 +0900 [thread overview]
Message-ID: <595AC867.6010008@samsung.com> (raw)
In-Reply-To: <fb5f390d-19f7-da5b-340b-e9f4afb7709c@samsung.com>
2017년 07월 03일 19:34에 Andrzej Hajda 이(가) 쓴 글:
> On 03.07.2017 09:27, Inki Dae wrote:
>> This patch moves of_drm_find_bridge call into probe.
>>
>> It doesn't need to call of_drm_find_bridge function every time
>> bind callback is called. It's enough to call this funcation
>> at probe one time.
>>
>> Suggested-by: Inki Dae <inki.dae@samsung.com>
>> Signed-off-by: Shuah Khan <shuahkh@osg.samsung.com>
>> Signed-off-by: Inki Dae <inki.dae@samsung.com>
>> ---
>> drivers/gpu/drm/exynos/exynos_drm_dsi.c | 23 ++++++++++++-----------
>> 1 file changed, 12 insertions(+), 11 deletions(-)
>>
>> diff --git a/drivers/gpu/drm/exynos/exynos_drm_dsi.c b/drivers/gpu/drm/exynos/exynos_drm_dsi.c
>> index b6a46d9..2412b23 100644
>> --- a/drivers/gpu/drm/exynos/exynos_drm_dsi.c
>> +++ b/drivers/gpu/drm/exynos/exynos_drm_dsi.c
>> @@ -1661,7 +1661,6 @@ static int exynos_dsi_bind(struct device *dev, struct device *master,
>> struct drm_encoder *encoder = dev_get_drvdata(dev);
>> struct exynos_dsi *dsi = encoder_to_dsi(encoder);
>> struct drm_device *drm_dev = data;
>> - struct drm_bridge *bridge;
>> int ret;
>>
>> ret = exynos_drm_crtc_get_pipe_from_type(drm_dev,
>> @@ -1685,12 +1684,6 @@ static int exynos_dsi_bind(struct device *dev, struct device *master,
>> return ret;
>> }
>>
>> - if (dsi->bridge_node) {
>> - bridge = of_drm_find_bridge(dsi->bridge_node);
>> - if (bridge)
>> - drm_bridge_attach(encoder, bridge, NULL);
>> - }
>> -
>> return mipi_dsi_host_register(&dsi->dsi_host);
>> }
>>
>> @@ -1798,6 +1791,18 @@ static int exynos_dsi_probe(struct platform_device *pdev)
>>
>> platform_set_drvdata(pdev, &dsi->encoder);
>>
>> + if (dsi->bridge_node) {
>> + struct drm_bridge *bridge;
>> +
>> + bridge = of_drm_find_bridge(dsi->bridge_node);
>> + if (!bridge)
>> + return -EPROBE_DEFER;
>> +
>> + of_node_put(dsi->bridge_node);
>> + drm_bridge_attach(&dsi->encoder, bridge, NULL);
>> + }
>> +
>> +
>
> One of benefits of componentized drivers is that they do not need to use
> probe deferall to wait for other components. There is guarantee that in
> bind callback all components are already probed.
> This patch looks like step back - it reintroduces probe deferall despite
> of existence of better mechanism.
Agree. This patch avoids of_drm_find_bridge function is called repeately and also this makes probe to be deferred.
I will skip this patch.
> Another issue is that now drm_bridge_attach is called before drm device
> creation, and before encoder is registered, even if it works for now, it
> does not seem proper, and it can beat us later.
> For sure bridge->dev is unitialized, and it can cause warnings.
>
> If you want to put bridge code together it should be put rather into
> bind callback.
Oops, sorry. as I commented[1] at the original patch from Shuah, drm_bridge_attach should be keepped in bind callback.
This is my mistake.
[1] https://patchwork.kernel.org/patch/9808497/
Thanks,
Inki Dae
>
> Regards
> Andrzej
>
>> pm_runtime_enable(dev);
>>
>> return component_add(dev, &exynos_dsi_component_ops);
>> @@ -1805,10 +1810,6 @@ static int exynos_dsi_probe(struct platform_device *pdev)
>>
>> static int exynos_dsi_remove(struct platform_device *pdev)
>> {
>> - struct exynos_dsi *dsi = platform_get_drvdata(pdev);
>> -
>> - of_node_put(dsi->bridge_node);
>> -
>> pm_runtime_disable(&pdev->dev);
>>
>> component_del(&pdev->dev, &exynos_dsi_component_ops);
>
>
>
>
_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel
next prev parent reply other threads:[~2017-07-03 22:42 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <CGME20170703072800epcas1p3247364bee692c338920c73bb856e8fad@epcas1p3.samsung.com>
2017-07-03 7:27 ` [PATCH 0/2] drm/exynos: clean up bridge binding Inki Dae
2017-07-03 7:27 ` [PATCH 1/2] drm/exynos: dsi: move of_drm_find_bridge call into probe Inki Dae
2017-07-03 10:34 ` Andrzej Hajda
2017-07-03 22:42 ` Inki Dae [this message]
2017-07-03 19:05 ` Krzysztof Kozlowski
2017-07-03 22:48 ` Inki Dae
2017-07-03 7:27 ` [PATCH 2/2] drm/exynos: mic: add a bridge at probe Inki Dae
2017-07-03 10:37 ` Andrzej Hajda
2017-07-05 7:04 ` Hoegeun Kwon
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=595AC867.6010008@samsung.com \
--to=inki.dae@samsung.com \
--cc=a.hajda@samsung.com \
--cc=dri-devel@lists.freedesktop.org \
--cc=linux-samsung-soc@vger.kernel.org \
--cc=shuahkh@osg.samsung.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.