Re: -EPROBE_DEFER and failed DSI panel probe

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Daniel Vetter <daniel@xxxxxxxx> writes:

> On Mon, Nov 20, 2017 at 08:53:05AM +0100, Andrzej Hajda wrote:
>> On 18.11.2017 02:16, Eric Anholt wrote:
>> > Andrzej Hajda <a.hajda@xxxxxxxxxxx> writes:
>> >
>> >> On 16.11.2017 21:27, Eric Anholt wrote:
>> >>> Andrzej Hajda <a.hajda@xxxxxxxxxxx> writes:
>> >>>
>> >>>> On 15.11.2017 21:26, Eric Anholt wrote:
>> >>>>> I'm happy to have the DSI panel finally working on VC4 (just waiting on
>> >>>>> https://lists.freedesktop.org/archives/dri-devel/2017-October/156407.html),
>> >>>>> but now I've got another problem to solve.  It would be great if I could
>> >>>>> include the DSI panel in our upstream DT, so that it automatically
>> >>>>> worked when you plugged one in.  However, right now we return
>> >>>>> -EPROBE_DEFER during bind unless the panel has actually shown up.  This
>> >>>>> means that if you don't have the panel actually connected, you get this
>> >>>>> sequence at startup:
>> >>>>>
>> >>>>> [   10.719929] [drm] Initialized
>> >>>>> [   10.829510] vc4_hdmi 3f902000.hdmi: vc4-hdmi-hifi <-> 3f902000.hdmi mapping ok
>> >>>>> [   10.844043] vc4-drm soc:gpu: bound 3f902000.hdmi (ops vc4_hdmi_ops [vc4])
>> >>>>> [   10.848626] vc4-drm soc:gpu: bound 3f806000.vec (ops vc4_vec_ops [vc4])
>> >>>>> [   10.850214] vc4-drm soc:gpu: failed to bind 3f700000.dsi (ops vc4_dsi_ops [vc4]): -517
>> >>>>> [   10.856559] vc4-drm soc:gpu: master bind failed: -517
>> >>>>>
>> >>>>> [...]
>> >>>>>
>> >>>>> [   10.967718] rpi_touchscreen 3-0045: Atmel I2C read failed: -6
>> >>>>>
>> >>>>> Once the panel driver fails to probe, we never get asked to re-bind vc4,
>> >>>>> and drm_of_find_panel_or_bridge looks like it would just give us
>> >>>>> -EPROBE_DEFER again since the panel still wasn't registered.
>> >>>>>
>> >>>>> Does anyone have any suggestions for handling this?
>> >>>> I guess you should call component_add only when all required resources
>> >>>> are present(including panel), I suppose moving it to vc4_dsi_host_attach
>> >>>> should help.
>> >>> How can I decide when the panel driver has tried to probe and failed,
>> >>> versus not tried to probe yet?  find_panel_or_bridge gives me
>> >>> -EPROBE_DEFER either way.
>> >>>
>> >>>> On the other side I am curious why EPROBE_DEFER from bind does not fail
>> >>>> probing of some component (the last one probed), with proper error
>> >>>> propagation it should cause defer_probing of one of the components or
>> >>>> master, and probe/bind should be retried after panel's probe.
>> >>> The panel probe failed, though, so there's no trigger to re-probe other
>> >>> drivers.
>> >> OK, I misunderstood your problem. And after 2nd read I am not sure what
>> >> do you want to achieve exactly?
>> >>
>> >> Do you want to 'hotplug' DSI panel? Or just make it working with and
>> >> without the panel. In 2nd case other paths (HDMI) should still work, I
>> >> guess.
>> > Yeah, the second thing.  I would like to use a single DT to describe a
>> > platform where the panel may or may not be present, so the panel driver
>> > (panel-raspberrypi-touchscreen.c) will throw an error from the I2C part
>> > of the probe or not instead of creating the DSI device and attaching the
>> > panel.
>> >
>> >> Lets assume that you are interested in the latter case. There could be
>> >> multiple solutions more or less hacky:
>> >>
>> >> 1. Use connector's HPD infrastructure to signal presence of the panel,
>> >> ie. in mipi_dsi::host_(attach|detach) callback you grab the panel and
>> >> change connector status to connected|disconnected and calls
>> >> drm_kms_helper_hotplug_event, it is done this way in exynos_dsi_host_attach.
>> > This is basically what I had before all the review reworks, and the
>> > regression from this state is keeping me from merging the current driver
>> > downstream.
>> >
>> > This option is unfortunate because we'll have forced *some* output on at
>> > boot time, and then when the panel driver shows up later we don't resize
>> > the fbcon to the panel's size.
>> 
>> This issue can be solved using deffered fbdev registration, ie fbdev is
>> registered after some  connector(or specific one, up to you) becomes
>> connected.
>
> Just jumping on on this part here: Deferred fbdev probe is merged now,
> which means as long as really nothing is connected, fbdev won't force
> anything.
>
> The exception is still analog outputs where we report "unknown", in that
> case fbdev still tries to light that up right away, just in case. Not sure
> that applies to the rpi with the tv-out.

Yeah, TV-out reports unknown for us as well.

Attachment: signature.asc
Description: PGP signature

_______________________________________________
dri-devel mailing list
dri-devel@xxxxxxxxxxxxxxxxxxxxx
https://lists.freedesktop.org/mailman/listinfo/dri-devel

[Index of Archives]     [Linux DRI Users]     [Linux Intel Graphics]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux