[Ask for help] i.MX6 dual display

Sean Nyekjær sean.nyekjaer at prevas.dk
Mon Dec 18 11:47:01 UTC 2017


Hi Philipp
>
>> I have an i.MX6Q running 4.9 LTS with etnaviv.
>> We would like to have both the HDMI and LVDS outputs enabled a once.
>>
>> If I enable hdmi and lvds in the devicetree, we have only output on the
>> hdmi port.
> Probably both LVDS and HDMI are clocked from the video PLL (PLL5). It is
> rather unlikely to have a combination of LVDS Display and HDMI mode that
> can be driven from the same PLL frequency, as the LVDS serializer input
> clock is 3.5 times or 7 times the LVDS pixel clock.
> You can check the clock tree in /sys/kernel/debug/clk/clk_summary.
>
> If you want to support connecting arbitrary monitors at all, you'll have
> to move the LDB clock input to another PLL that can be set to the LVDS
> serializer clock rate without disturbing other peripherals.
> Due to a bug in the i.MX6Q LDB clock dividers, this has to be done once,
> early during boot, using the assigned-clocks/assigned-clock-parents
> device tree properties of the &clks node. To find example device trees,
> see:
>
>    git grep -A3 assigned-clocks.*LDB_DI0_SEL arch/arm/boot/dts
>
I have this in my devicetree:
&clks {
      assigned-clocks = <&clks IMX6QDL_CLK_LDB_DI0_SEL>,
             <&clks IMX6QDL_CLK_LDB_DI1_SEL>;
     assigned-clock-parents = <&clks IMX6QDL_CLK_PLL3_USB_OTG>,
             <&clks IMX6QDL_CLK_PLL3_USB_OTG>;
};
That should be enough?
>> So basically I have 2 questions:
>> Is it possible to have both LVDS and HDMI enabled at once from the same ipu?
> Yes, if the resolution isn't too high. The IPU pixel clock / bandwidth
> limitations depend on whether both DIs are active.
> Also only one of the displays will have overlay plane support, if that
> is relevant to you, since there's only one DP that can do composition in
> each IPU.
Any way to tell if the IPU pixel clock is too high?
My LVDS display:
static const struct drm_display_mode xin_sun_xf1011280800_mode = {
         .clock       = 71100,
         .hdisplay    = 1280,
         .hsync_start = 1280 + 40,
         .hsync_end   = 1280 + 40 + 80,
         .htotal      = 1280 + 40 + 80 + 40,
         .vdisplay    = 800,
         .vsync_start = 800 + 10,
         .vsync_end   = 800 + 10 + 10,
         .vtotal      = 800 + 10 + 10 + 3,
         .vrefresh    = 60,
         .flags       = DRM_MODE_FLAG_NVSYNC | DRM_MODE_FLAG_NHSYNC,
}
HDMI would be fine in 720p mode.

>
>> Can i move the HDMI output to the other ipu and how?
> Yes, see arch/arm/boot/dts/imx6q-utilite-pro.dts for an example: After
> severing the OF graph links between the IPU1 DIs and the HDMI encoder
> in the device tree, the HDMI output can only be driven by IPU2:
>
>    /delete-node/&ipu1_di0_hdmi;
>    /delete-node/&hdmi_mux_0;
>    /delete-node/&ipu1_di1_hdmi;
>    /delete-node/&hdmi_mux_1;
Thanks if I add this I get LVDS output and a blank HDMI output.
I have only one fb device. It it possible to get a second one for IPU2?

My prefered option would be the HDMI and LVDS mirrored.

Thanks for your help :-)
/Sean



More information about the dri-devel mailing list