Lines Matching full:panel

46  * struct panel_delay - Describes delays for a simple panel.
52 * The time (in milliseconds) that it takes after powering the panel
56 * NOTE: on some old panel data this number appears to be much too big.
108 * @enable: Time for the panel to display a valid frame.
110 * The time (in milliseconds) that it takes for the panel to
121 * @disable: Time for the panel to turn the display off.
123 * The time (in milliseconds) that it takes for the panel to
134 * The time (in milliseconds) that it takes for the panel
148 * struct panel_desc - Describes a simple panel.
152 * @modes: Pointer to array of fixed modes appropriate for this panel.
177 /** @size: Structure containing the physical size of this panel. */
190 /** @delay: Structure containing various delay values for this panel. */
195 * struct edp_panel_entry - Maps panel ID to delay / panel name.
198 /** @panel_id: 32-bit ID for panel, encoded with drm_edid_encode_panel_id(). */
201 /** @delay: The power sequencing delays needed for this panel. */
204 /** @name: Name of this panel (for printing to logs). */
239 static inline struct panel_edp *to_panel_edp(struct drm_panel *panel) in to_panel_edp() argument
241 return container_of(panel, struct panel_edp, base); in to_panel_edp()
244 static unsigned int panel_edp_get_timings_modes(struct panel_edp *panel, in panel_edp_get_timings_modes() argument
250 for (i = 0; i < panel->desc->num_timings; i++) { in panel_edp_get_timings_modes()
251 const struct display_timing *dt = &panel->desc->timings[i]; in panel_edp_get_timings_modes()
257 dev_err(panel->base.dev, "failed to add mode %ux%u\n", in panel_edp_get_timings_modes()
266 if (panel->desc->num_timings == 1) in panel_edp_get_timings_modes()
276 static unsigned int panel_edp_get_display_modes(struct panel_edp *panel, in panel_edp_get_display_modes() argument
282 for (i = 0; i < panel->desc->num_modes; i++) { in panel_edp_get_display_modes()
283 const struct drm_display_mode *m = &panel->desc->modes[i]; in panel_edp_get_display_modes()
287 dev_err(panel->base.dev, "failed to add mode %ux%u@%u\n", in panel_edp_get_display_modes()
295 if (panel->desc->num_modes == 1) in panel_edp_get_display_modes()
307 static int panel_edp_override_edid_mode(struct panel_edp *panel, in panel_edp_override_edid_mode() argument
315 dev_err(panel->base.dev, "failed to add additional mode\n"); in panel_edp_override_edid_mode()
325 static int panel_edp_get_non_edid_modes(struct panel_edp *panel, in panel_edp_get_non_edid_modes() argument
329 bool has_override = panel->override_mode.type; in panel_edp_get_non_edid_modes()
332 if (!panel->desc) in panel_edp_get_non_edid_modes()
337 &panel->override_mode); in panel_edp_get_non_edid_modes()
342 dev_err(panel->base.dev, "failed to add override mode\n"); in panel_edp_get_non_edid_modes()
347 if (num == 0 && panel->desc->num_timings) in panel_edp_get_non_edid_modes()
348 num = panel_edp_get_timings_modes(panel, connector); in panel_edp_get_non_edid_modes()
356 WARN_ON(panel->desc->num_timings && panel->desc->num_modes); in panel_edp_get_non_edid_modes()
358 num = panel_edp_get_display_modes(panel, connector); in panel_edp_get_non_edid_modes()
360 connector->display_info.bpc = panel->desc->bpc; in panel_edp_get_non_edid_modes()
361 connector->display_info.width_mm = panel->desc->size.width; in panel_edp_get_non_edid_modes()
362 connector->display_info.height_mm = panel->desc->size.height; in panel_edp_get_non_edid_modes()
381 static int panel_edp_disable(struct drm_panel *panel) in panel_edp_disable() argument
383 struct panel_edp *p = to_panel_edp(panel); in panel_edp_disable()
407 static int panel_edp_unprepare(struct drm_panel *panel) in panel_edp_unprepare() argument
409 struct panel_edp *p = to_panel_edp(panel); in panel_edp_unprepare()
416 pm_runtime_mark_last_busy(panel->dev); in panel_edp_unprepare()
417 ret = pm_runtime_put_autosuspend(panel->dev); in panel_edp_unprepare()
526 static int panel_edp_prepare(struct drm_panel *panel) in panel_edp_prepare() argument
528 struct panel_edp *p = to_panel_edp(panel); in panel_edp_prepare()
535 ret = pm_runtime_get_sync(panel->dev); in panel_edp_prepare()
537 pm_runtime_put_autosuspend(panel->dev); in panel_edp_prepare()
546 static int panel_edp_enable(struct drm_panel *panel) in panel_edp_enable() argument
548 struct panel_edp *p = to_panel_edp(panel); in panel_edp_enable()
559 * However, we can only count this if HPD is readable by the panel in panel_edp_enable()
587 static int panel_edp_get_modes(struct drm_panel *panel, in panel_edp_get_modes() argument
590 struct panel_edp *p = to_panel_edp(panel); in panel_edp_get_modes()
599 pm_runtime_get_sync(panel->dev); in panel_edp_get_modes()
620 pm_runtime_mark_last_busy(panel->dev); in panel_edp_get_modes()
621 pm_runtime_put_autosuspend(panel->dev); in panel_edp_get_modes()
638 static int panel_edp_get_timings(struct drm_panel *panel, in panel_edp_get_timings() argument
642 struct panel_edp *p = to_panel_edp(panel); in panel_edp_get_timings()
655 static enum drm_panel_orientation panel_edp_get_orientation(struct drm_panel *panel) in panel_edp_get_orientation() argument
657 struct panel_edp *p = to_panel_edp(panel); in panel_edp_get_orientation()
664 struct drm_panel *panel = s->private; in detected_panel_show() local
665 struct panel_edp *p = to_panel_edp(panel); in detected_panel_show()
679 static void panel_edp_debugfs_init(struct drm_panel *panel, struct dentry *root) in panel_edp_debugfs_init() argument
681 debugfs_create_file("detected_panel", 0600, root, panel, &detected_panel_fops); in panel_edp_debugfs_init()
699 struct panel_edp *panel, in panel_edp_parse_panel_timing_node() argument
702 const struct panel_desc *desc = panel->desc; in panel_edp_parse_panel_timing_node()
707 dev_err(dev, "Reject override mode: panel has a fixed mode\n"); in panel_edp_parse_panel_timing_node()
715 for (i = 0; i < panel->desc->num_timings; i++) { in panel_edp_parse_panel_timing_node()
716 const struct display_timing *dt = &panel->desc->timings[i]; in panel_edp_parse_panel_timing_node()
732 drm_display_mode_from_videomode(&vm, &panel->override_mode); in panel_edp_parse_panel_timing_node()
733 panel->override_mode.type |= DRM_MODE_TYPE_DRIVER | in panel_edp_parse_panel_timing_node()
738 if (WARN_ON(!panel->override_mode.type)) in panel_edp_parse_panel_timing_node()
744 static int generic_edp_panel_probe(struct device *dev, struct panel_edp *panel) in generic_edp_panel_probe() argument
757 panel->desc = desc; in generic_edp_panel_probe()
769 /* Power the panel on so we can read the EDID */ in generic_edp_panel_probe()
772 dev_err(dev, "Couldn't power on panel to read EDID: %d\n", ret); in generic_edp_panel_probe()
776 panel_id = drm_edid_get_panel_id(panel->ddc); in generic_edp_panel_probe()
778 dev_err(dev, "Couldn't identify panel via EDID\n"); in generic_edp_panel_probe()
784 panel->detected_panel = find_edp_panel(panel_id); in generic_edp_panel_probe()
791 if (WARN_ON(!panel->detected_panel)) { in generic_edp_panel_probe()
793 "Unknown panel %s %#06x, using conservative timings\n", in generic_edp_panel_probe()
797 * It's highly likely that the panel will work if we use very in generic_edp_panel_probe()
814 panel->detected_panel = ERR_PTR(-EINVAL); in generic_edp_panel_probe()
817 vend, panel->detected_panel->name, product_id); in generic_edp_panel_probe()
820 desc->delay = *panel->detected_panel->delay; in generic_edp_panel_probe()
834 struct panel_edp *panel; in panel_edp_probe() local
839 panel = devm_kzalloc(dev, sizeof(*panel), GFP_KERNEL); in panel_edp_probe()
840 if (!panel) in panel_edp_probe()
843 panel->enabled = false; in panel_edp_probe()
844 panel->prepared_time = 0; in panel_edp_probe()
845 panel->desc = desc; in panel_edp_probe()
846 panel->aux = aux; in panel_edp_probe()
848 panel->no_hpd = of_property_read_bool(dev->of_node, "no-hpd"); in panel_edp_probe()
849 if (!panel->no_hpd) { in panel_edp_probe()
850 err = panel_edp_get_hpd_gpio(dev, panel); in panel_edp_probe()
855 panel->supply = devm_regulator_get(dev, "power"); in panel_edp_probe()
856 if (IS_ERR(panel->supply)) in panel_edp_probe()
857 return PTR_ERR(panel->supply); in panel_edp_probe()
859 panel->enable_gpio = devm_gpiod_get_optional(dev, "enable", in panel_edp_probe()
861 if (IS_ERR(panel->enable_gpio)) in panel_edp_probe()
862 return dev_err_probe(dev, PTR_ERR(panel->enable_gpio), in panel_edp_probe()
865 err = of_drm_get_panel_orientation(dev->of_node, &panel->orientation); in panel_edp_probe()
873 panel->ddc = of_find_i2c_adapter_by_node(ddc); in panel_edp_probe()
876 if (!panel->ddc) in panel_edp_probe()
879 panel->ddc = &aux->ddc; in panel_edp_probe()
882 if (!of_get_display_timing(dev->of_node, "panel-timing", &dt)) in panel_edp_probe()
883 panel_edp_parse_panel_timing_node(dev, panel, &dt); in panel_edp_probe()
885 dev_set_drvdata(dev, panel); in panel_edp_probe()
887 drm_panel_init(&panel->base, dev, &panel_edp_funcs, DRM_MODE_CONNECTOR_eDP); in panel_edp_probe()
889 err = drm_panel_of_backlight(&panel->base); in panel_edp_probe()
894 * We use runtime PM for prepare / unprepare since those power the panel in panel_edp_probe()
896 * to optimize powering the panel on briefly to read the EDID before in panel_edp_probe()
897 * fully enabling the panel. in panel_edp_probe()
903 if (of_device_is_compatible(dev->of_node, "edp-panel")) { in panel_edp_probe()
904 err = generic_edp_panel_probe(dev, panel); in panel_edp_probe()
907 "Couldn't detect panel nor find a fallback\n"); in panel_edp_probe()
910 /* generic_edp_panel_probe() replaces desc in the panel */ in panel_edp_probe()
911 desc = panel->desc; in panel_edp_probe()
916 if (!panel->base.backlight && panel->aux) { in panel_edp_probe()
918 err = drm_panel_dp_aux_backlight(&panel->base, panel->aux); in panel_edp_probe()
925 drm_panel_add(&panel->base); in panel_edp_probe()
933 if (panel->ddc && (!panel->aux || panel->ddc != &panel->aux->ddc)) in panel_edp_probe()
934 put_device(&panel->ddc->dev); in panel_edp_probe()
941 struct panel_edp *panel = dev_get_drvdata(dev); in panel_edp_remove() local
943 drm_panel_remove(&panel->base); in panel_edp_remove()
944 drm_panel_disable(&panel->base); in panel_edp_remove()
945 drm_panel_unprepare(&panel->base); in panel_edp_remove()
949 if (panel->ddc && (!panel->aux || panel->ddc != &panel->aux->ddc)) in panel_edp_remove()
950 put_device(&panel->ddc->dev); in panel_edp_remove()
952 kfree(panel->edid); in panel_edp_remove()
953 panel->edid = NULL; in panel_edp_remove()
958 struct panel_edp *panel = dev_get_drvdata(dev); in panel_edp_shutdown() local
960 drm_panel_disable(&panel->base); in panel_edp_shutdown()
961 drm_panel_unprepare(&panel->base); in panel_edp_shutdown()
1239 * When power is first given to the panel there's a short
1743 .compatible = "edp-panel",
1910 * platform_of_match table (if a panel is listed in both places).
2000 const struct edp_panel_entry *panel; in find_edp_panel() local
2005 for (panel = edp_panels; panel->panel_id; panel++) in find_edp_panel()
2006 if (panel->panel_id == panel_id) in find_edp_panel()
2007 return panel; in find_edp_panel()
2016 /* Skip one since "edp-panel" is only supported on DP AUX bus */ in panel_edp_platform_probe()
2042 .name = "panel-edp",
2074 .name = "panel-simple-dp-aux",