Hi Nikola, thanks for the quick re-spin. There is still a few things that needs to be addressed though. Sorry for not catching these the first time. On Tue, Aug 17, 2021 at 06:36:05PM +0200, Nikola Pavlica wrote: > The model and make of the LCD panel of the Vivax TPC-9150 is unknown, > hence the panel settings that were retrieved with a FEX dump are named HEX dump? > after the device NOT the actual panel. > > The LCD in question is a 50 pin MISO TFT LCD panel of the resolution > 1024x600 used by the aforementioned device. > > Version 2, as Thierry kindly suggested that I fix the order in which the > panel was ordered compared to others. > > Version 3, filling in the required info suggested by Sam. Plus some > factual issues that I've corrected myself (tested working) > > Thanks, > Nikola > > Signed-off-by: Nikola Pavlica <pavlica.nikola@xxxxxxxxx> > --- > drivers/gpu/drm/panel/panel-simple.c | 29 ++++++++++++++++++++++++++++ > 1 file changed, 29 insertions(+) > > diff --git a/drivers/gpu/drm/panel/panel-simple.c b/drivers/gpu/drm/panel/panel-simple.c > index 4e2dad314c79..f6b3e58c162b 100644 > --- a/drivers/gpu/drm/panel/panel-simple.c > +++ b/drivers/gpu/drm/panel/panel-simple.c > @@ -3989,6 +3989,32 @@ static const struct panel_desc urt_umsh_8596md_parallel = { > .bus_format = MEDIA_BUS_FMT_RGB666_1X18, > }; > > +static const struct drm_display_mode vivax_tpc9150_panel_mode = { > + .clock = 60000, > + .hdisplay = 1024, > + .hsync_start = 1024 + 160, > + .hsync_end = 1024 + 160 + 100, > + .htotal = 1024 + 160 + 100 + 60, > + .vdisplay = 600, > + .vsync_start = 600 + 12, > + .vsync_end = 600 + 12 + 10, > + .vtotal = 600 + 12 + 10 + 13, > +}; > + > +static const struct panel_desc vivax_tpc9150_panel = { > + .modes = &vivax_tpc9150_panel_mode, > + .num_modes = 1, Most panels put .bpc right above .size, so they follow the order in the struct. This is bikeshedding but my OCD triggered here. > + .size = { > + .width = 200, > + .height = 115, > + }, > + .bpc = 6, > + .bus_format = MEDIA_BUS_FMT_RGB666_1X24, This does not build - I have no MEDIA_BUS_FMT_RGB666_1X24 in my kernel (drm-misc-next). With an LVDS connector and bpc equals 6 my bet is on: MEDIA_BUS_FMT_RGB666_1X7X3_SPWG This is from looking at similar panels. > + .bus_flags = DRM_BUS_FLAG_DE_HIGH, > + .connector_type = DRM_MODE_CONNECTOR_LVDS, > +}; > + > + > static const struct drm_display_mode vl050_8048nt_c01_mode = { > .clock = 33333, > .hdisplay = 800, > @@ -4490,6 +4516,9 @@ static const struct of_device_id platform_of_match[] = { > }, { > .compatible = "urt,umsh-8596md-20t", > .data = &urt_umsh_8596md_parallel, > + }, { > + .compatible = "vivax,tpc9150-panel", vivax is an unknown vendor, needs to be added to Documentation/devicetree/bindings/vendor-prefixes.yaml in a separate patch. tpc9150-panel should be added to Documentation/devicetree/bindings/display/panel/panel-simple.yaml or at least I assume this is the file to add it to. Again as a separate patch. For the two binding related patches see Documentation/devicetree/bindings/submitting-patches.rst Sorry for making this difficult, but we need it done right. Sam