[PATCH v5 05/14] drm/exynos: dsi: add pass TE host ops to support LCD I80 interface
YoungJun Cho
yj44.cho at samsung.com
Mon Jul 14 03:45:28 PDT 2014
Hi Thierry,
On 07/14/2014 06:41 PM, Thierry Reding wrote:
> On Mon, Jul 14, 2014 at 06:22:39PM +0900, YoungJun Cho wrote:
>> Hi Thierry,
>>
>> Thank you for comment.
>>
>> On 07/10/2014 04:38 PM, Thierry Reding wrote:
>>> On Thu, Jul 10, 2014 at 10:06:07AM +0900, YoungJun Cho wrote:
>>>> On 07/10/2014 12:22 AM, Thierry Reding wrote:
>>>>> On Tue, Jul 08, 2014 at 09:39:38AM +0900, YoungJun Cho wrote:
>>>>>> To support LCD I80 interface, the DSI host calls this function
>>>>>> to notify the panel tearing effect synchronization signal to
>>>>>> the CRTC device manager to trigger to transfer video image.
>>>>>>
>>>>>> Signed-off-by: YoungJun Cho <yj44.cho at samsung.com>
>>>>>> Acked-by: Inki Dae <inki.dae at samsung.com>
>>>>>> Acked-by: Kyungmin Park <kyungmin.park at samsung.com>
>>>>>> ---
>>>>>> drivers/gpu/drm/exynos/exynos_drm_dsi.c | 11 +++++++++++
>>>>>> include/drm/drm_mipi_dsi.h | 7 +++++++
>>>>>> 2 files changed, 18 insertions(+)
>>>>>>
>>>>>> diff --git a/drivers/gpu/drm/exynos/exynos_drm_dsi.c b/drivers/gpu/drm/exynos/exynos_drm_dsi.c
>>>>>> index dad543a..76e34ca 100644
>>>>>> --- a/drivers/gpu/drm/exynos/exynos_drm_dsi.c
>>>>>> +++ b/drivers/gpu/drm/exynos/exynos_drm_dsi.c
>>>>>> @@ -24,6 +24,7 @@
>>>>>> #include <video/mipi_display.h>
>>>>>> #include <video/videomode.h>
>>>>>>
>>>>>> +#include "exynos_drm_crtc.h"
>>>>>> #include "exynos_drm_drv.h"
>>>>>>
>>>>>> /* returns true iff both arguments logically differs */
>>>>>> @@ -1041,10 +1042,20 @@ static ssize_t exynos_dsi_host_transfer(struct mipi_dsi_host *host,
>>>>>> return (ret < 0) ? ret : xfer.rx_done;
>>>>>> }
>>>>>>
>>>>>> +static void exynos_dsi_host_pass_te(struct mipi_dsi_host *host)
>>>>>> +{
>>>>>> + struct exynos_dsi *dsi = host_to_dsi(host);
>>>>>> + struct drm_encoder *encoder = dsi->encoder;
>>>>>> +
>>>>>> + if (dsi->state & DSIM_STATE_ENABLED)
>>>>>> + exynos_drm_crtc_te_handler(encoder->crtc);
>>>>>> +}
>>>>>> +
>>>>>> static const struct mipi_dsi_host_ops exynos_dsi_ops = {
>>>>>> .attach = exynos_dsi_host_attach,
>>>>>> .detach = exynos_dsi_host_detach,
>>>>>> .transfer = exynos_dsi_host_transfer,
>>>>>> + .pass_te = exynos_dsi_host_pass_te,
>>>>>> };
>>>>>>
>>>>>> static int exynos_dsi_poweron(struct exynos_dsi *dsi)
>>>>>> diff --git a/include/drm/drm_mipi_dsi.h b/include/drm/drm_mipi_dsi.h
>>>>>> index 944f33f..3f21bea 100644
>>>>>> --- a/include/drm/drm_mipi_dsi.h
>>>>>> +++ b/include/drm/drm_mipi_dsi.h
>>>>>> @@ -49,6 +49,12 @@ struct mipi_dsi_msg {
>>>>>> * @detach: detach DSI device from DSI host
>>>>>> * @transfer: send and/or receive DSI packet, return number of received bytes,
>>>>>> * or error
>>>>>> + * @pass_te: call the crtc te_handler() callback from DSI host.
>>>>>> + * The panel generates tearing effect synchronization signal between
>>>>>> + * MCU and FB to display video images. And the display controller
>>>>>> + * should trigger to transfer video image at this signal. So the panel
>>>>>> + * receives the TE IRQ, then calls this function to notify it to the
>>>>>> + * display controller.
>>>>>> */
>>>>>> struct mipi_dsi_host_ops {
>>>>>> int (*attach)(struct mipi_dsi_host *host,
>>>>>> @@ -57,6 +63,7 @@ struct mipi_dsi_host_ops {
>>>>>> struct mipi_dsi_device *dsi);
>>>>>> ssize_t (*transfer)(struct mipi_dsi_host *host,
>>>>>> struct mipi_dsi_msg *msg);
>>>>>> + void (*pass_te)(struct mipi_dsi_host *host);
>>>>>
>>>>> I've objected to this particular change before and that objection still
>>>>> stands. I don't see how this is related to DSI. It seems like an
>>>>> implementation detail of this particular setup and I think it should be
>>>>> handled differently (within the Exynos DSI controller implementation
>>>>> possibly).
>>>>>
>>>>
>>>> Okay, I understand what you mean.
>>>> As you know, this function is called by panel TE interrupt handler, so it
>>>> could be accessed by panel.
>>>> Do you have any good idea for panel to access exynos_drm_dsi directly
>>>> without mipi_dis_host_ops?
>>>
>>> I've gone through the DSI specification again and the only mention of
>>> the tearing effect is in section 8.12 "TE Signaling in DSI". That says
>>> the following:
>>>
>>> A Command Mode display module has its own timing controller and
>>> local frame buffer for display refresh. In some cases the host
>>> processor needs to be notified of timing events on the display
>>> module, e.g. the start of vertical blanking or similar timing
>>> information. In a traditional parallel-bus interface like DBI-2,
>>> a dedicated signal wire labeled TE (Tearing Effect) is provided
>>> to convey such timing information to the host processor. In a
>>> DSI system, the same information, with reasonably low latency,
>>> shall be transmitted from the display module to the host
>>> processor when requested, using the bidirectional Data Lane.
>>>
>>> My interpretation of that is that a DSI peripheral doesn't have a
>>> dedicated TE signal. Now the panel that you want to support here seems
>>> to have one, so I'm wondering if maybe it isn't a DSI panel at all but
>>> rather DBI.
>>
>> Uhm, this panel is DSI panel right. It provides TE external pad to transfer
>> TE pulse to host AP and it also provides TE relevant 3 DCS, so host AP could
>> choose either of them.
>> But I think it's better to use IRQ instead of polling method.
>
> According to the specification you don't have to rely on polling. You
> can simply pass control of the bus to the peripheral (via a BTA
> sequence) and then wait for the peripheral to signal TE.
>
I need to check that the Exynos DSIM driver supports this BTA sequence.
> That said, I've been doing some research and it seems like we have a
> somewhat similar feature on Tegra. What happens there is that there are
> three GPIO pins that can be repurposed for TE signalling. But as opposed
> to using them as interrupts the display controller can be configured to
> use them, upon which it will automatically handle the TE signal by
> sending the next frame.
Could you explain more detail how the Tegra display controller could be
configured with this GPIO pins?
I have no idea except that the display controller registers this GPIO as
an IRQ.
>
> So we have at least two very different implementations of this on two
> different SoCs. Further the specification explicitly recommends using
> the BTA sequence and DSI protocol to wait for TE. So I still think that
> controllers that provide an additional, non-spec compliant method to
> signal TE should handle it separately rather than within DSI. Otherwise
> we essentially need to make the DSI "core" aware of all these quirks,
> and I'd rather avoid that.
You mean, the DSI specification guides to use BTA, so it's better to use
display controller rather than DSIM, right?
>
>> As Inki commented before, I'll try to use remote-endpoint property of DSI
>> device node in exynos DSIM driver and call FIMD notifier.
>
> Sounds like it matches what I said above. I'm not a huge fan of
> notifiers, but if it works for you I suppose that's fine. The
> alternative would be to directly call a FIMD function, which is
> somewhat more explicit than a notifier.
Yes, I also like explicit call, so I want to use dsi_host_ops and calls
it in panel. But there is an objection to use dis_host_ops, we think
notifier in exynos dsim for fimd(display controller).
Thank you.
Best regards YJ
>
> Thierry
>
More information about the dri-devel
mailing list