When the initial drivers were submitted, some of the timing was hard coded and did not allow for any MIPI-DSI panel to be attached. In general, panels or bridges can only be supported if MIPI-DSI lanes were 4. If the number of lanes were 3,2,1, the math no longer works out.
A new API was created for the clock driver because the behaivior of the clock driver depends on DPI vs MIPI, the bpp, and the number of MIPI lanes. Testing: * RZ/G2L SMARC (MIPI-DSI to HDMI bridge, lanes = 4) * RZ/G2L-SBC (MIPI-DSI to LCD panel, lanes = 2) * RZ/G2UL SMARC (DPI to HDMI bridge) * Multiple monitors, multiple resolutions Chris Brandt (2): clk: renesas: rzg2l: Remove DSI clock rate restrictions drm: renesas: rz-du: Set DSI divider based on target MIPI device drivers/clk/renesas/rzg2l-cpg.c | 147 ++++++++++++++++-- .../gpu/drm/renesas/rz-du/rzg2l_mipi_dsi.c | 18 +++ include/linux/clk/renesas.h | 12 ++ 3 files changed, 164 insertions(+), 13 deletions(-) -- 2.50.1
