Lines Matching +full:panel +full:- +full:dsi

1 // SPDX-License-Identifier: GPL-2.0
3 * Mantix MLAF057WE51 5.7" MIPI-DSI panel driver
11 #include <linux/media-bus-format.h>
22 #define DRV_NAME "panel-mantix-mlaf057we51"
24 /* Manufacturer specific Commands send via DSI */
31 struct drm_panel panel; member
43 static inline struct mantix *panel_to_mantix(struct drm_panel *panel) in panel_to_mantix() argument
45 return container_of(panel, struct mantix, panel); in panel_to_mantix()
50 struct mipi_dsi_device *dsi = to_mipi_dsi_device(ctx->dev); in mantix_init_sequence() local
51 struct device *dev = ctx->dev; in mantix_init_sequence()
54 * Init sequence was supplied by the panel vendor. in mantix_init_sequence()
56 mipi_dsi_generic_write_seq(dsi, MANTIX_CMD_OTP_STOP_RELOAD_MIPI, 0x5A); in mantix_init_sequence()
58 mipi_dsi_generic_write_seq(dsi, MANTIX_CMD_INT_CANCEL, 0x03); in mantix_init_sequence()
59 mipi_dsi_generic_write_seq(dsi, MANTIX_CMD_OTP_STOP_RELOAD_MIPI, 0x5A, 0x03); in mantix_init_sequence()
60 mipi_dsi_generic_write_seq(dsi, 0x80, 0xA9, 0x00); in mantix_init_sequence()
62 mipi_dsi_generic_write_seq(dsi, MANTIX_CMD_OTP_STOP_RELOAD_MIPI, 0x5A, 0x09); in mantix_init_sequence()
63 mipi_dsi_generic_write_seq(dsi, 0x80, 0x64, 0x00, 0x64, 0x00, 0x00); in mantix_init_sequence()
66 mipi_dsi_generic_write_seq(dsi, MANTIX_CMD_SPI_FINISH, 0xA5); in mantix_init_sequence()
67 mipi_dsi_generic_write_seq(dsi, MANTIX_CMD_OTP_STOP_RELOAD_MIPI, 0x00, 0x2F); in mantix_init_sequence()
70 dev_dbg(dev, "Panel init sequence done\n"); in mantix_init_sequence()
74 static int mantix_enable(struct drm_panel *panel) in mantix_enable() argument
76 struct mantix *ctx = panel_to_mantix(panel); in mantix_enable()
77 struct device *dev = ctx->dev; in mantix_enable()
78 struct mipi_dsi_device *dsi = to_mipi_dsi_device(dev); in mantix_enable() local
83 dev_err(ctx->dev, "Panel init sequence failed: %d\n", ret); in mantix_enable()
87 ret = mipi_dsi_dcs_exit_sleep_mode(dsi); in mantix_enable()
94 ret = mipi_dsi_dcs_set_display_on(dsi); in mantix_enable()
99 ret = mipi_dsi_turn_on_peripheral(dsi); in mantix_enable()
108 static int mantix_disable(struct drm_panel *panel) in mantix_disable() argument
110 struct mantix *ctx = panel_to_mantix(panel); in mantix_disable()
111 struct mipi_dsi_device *dsi = to_mipi_dsi_device(ctx->dev); in mantix_disable() local
114 ret = mipi_dsi_dcs_set_display_off(dsi); in mantix_disable()
116 dev_err(ctx->dev, "Failed to turn off the display: %d\n", ret); in mantix_disable()
118 ret = mipi_dsi_dcs_enter_sleep_mode(dsi); in mantix_disable()
120 dev_err(ctx->dev, "Failed to enter sleep mode: %d\n", ret); in mantix_disable()
126 static int mantix_unprepare(struct drm_panel *panel) in mantix_unprepare() argument
128 struct mantix *ctx = panel_to_mantix(panel); in mantix_unprepare()
130 gpiod_set_value_cansleep(ctx->tp_rstn_gpio, 1); in mantix_unprepare()
132 gpiod_set_value_cansleep(ctx->reset_gpio, 1); in mantix_unprepare()
134 regulator_disable(ctx->avee); in mantix_unprepare()
135 regulator_disable(ctx->avdd); in mantix_unprepare()
138 regulator_disable(ctx->vddi); in mantix_unprepare()
145 static int mantix_prepare(struct drm_panel *panel) in mantix_prepare() argument
147 struct mantix *ctx = panel_to_mantix(panel); in mantix_prepare()
151 dev_dbg(ctx->dev, "Resetting the panel\n"); in mantix_prepare()
152 ret = regulator_enable(ctx->vddi); in mantix_prepare()
154 dev_err(ctx->dev, "Failed to enable vddi supply: %d\n", ret); in mantix_prepare()
161 ret = regulator_enable(ctx->avdd); in mantix_prepare()
163 dev_err(ctx->dev, "Failed to enable avdd supply: %d\n", ret); in mantix_prepare()
169 ret = regulator_enable(ctx->avee); in mantix_prepare()
171 dev_err(ctx->dev, "Failed to enable avee supply: %d\n", ret); in mantix_prepare()
177 gpiod_set_value_cansleep(ctx->reset_gpio, 0); in mantix_prepare()
178 gpiod_set_value_cansleep(ctx->tp_rstn_gpio, 0); in mantix_prepare()
220 static int mantix_get_modes(struct drm_panel *panel, in mantix_get_modes() argument
223 struct mantix *ctx = panel_to_mantix(panel); in mantix_get_modes()
226 mode = drm_mode_duplicate(connector->dev, ctx->default_mode); in mantix_get_modes()
228 dev_err(ctx->dev, "Failed to add mode %ux%u@%u\n", in mantix_get_modes()
229 ctx->default_mode->hdisplay, ctx->default_mode->vdisplay, in mantix_get_modes()
230 drm_mode_vrefresh(ctx->default_mode)); in mantix_get_modes()
231 return -ENOMEM; in mantix_get_modes()
236 mode->type = DRM_MODE_TYPE_DRIVER | DRM_MODE_TYPE_PREFERRED; in mantix_get_modes()
237 connector->display_info.width_mm = mode->width_mm; in mantix_get_modes()
238 connector->display_info.height_mm = mode->height_mm; in mantix_get_modes()
241 drm_display_info_set_bus_formats(&connector->display_info, in mantix_get_modes()
256 static int mantix_probe(struct mipi_dsi_device *dsi) in mantix_probe() argument
258 struct device *dev = &dsi->dev; in mantix_probe()
264 return -ENOMEM; in mantix_probe()
265 ctx->default_mode = of_device_get_match_data(dev); in mantix_probe()
267 ctx->reset_gpio = devm_gpiod_get(dev, "reset", GPIOD_OUT_HIGH); in mantix_probe()
268 if (IS_ERR(ctx->reset_gpio)) { in mantix_probe()
270 return PTR_ERR(ctx->reset_gpio); in mantix_probe()
273 ctx->tp_rstn_gpio = devm_gpiod_get(dev, "mantix,tp-rstn", GPIOD_OUT_HIGH); in mantix_probe()
274 if (IS_ERR(ctx->tp_rstn_gpio)) { in mantix_probe()
275 dev_err(dev, "cannot get tp-rstn gpio\n"); in mantix_probe()
276 return PTR_ERR(ctx->tp_rstn_gpio); in mantix_probe()
279 mipi_dsi_set_drvdata(dsi, ctx); in mantix_probe()
280 ctx->dev = dev; in mantix_probe()
282 dsi->lanes = 4; in mantix_probe()
283 dsi->format = MIPI_DSI_FMT_RGB888; in mantix_probe()
284 dsi->mode_flags = MIPI_DSI_MODE_VIDEO | in mantix_probe()
287 ctx->avdd = devm_regulator_get(dev, "avdd"); in mantix_probe()
288 if (IS_ERR(ctx->avdd)) in mantix_probe()
289 return dev_err_probe(dev, PTR_ERR(ctx->avdd), "Failed to request avdd regulator\n"); in mantix_probe()
291 ctx->avee = devm_regulator_get(dev, "avee"); in mantix_probe()
292 if (IS_ERR(ctx->avee)) in mantix_probe()
293 return dev_err_probe(dev, PTR_ERR(ctx->avee), "Failed to request avee regulator\n"); in mantix_probe()
295 ctx->vddi = devm_regulator_get(dev, "vddi"); in mantix_probe()
296 if (IS_ERR(ctx->vddi)) in mantix_probe()
297 return dev_err_probe(dev, PTR_ERR(ctx->vddi), "Failed to request vddi regulator\n"); in mantix_probe()
299 drm_panel_init(&ctx->panel, dev, &mantix_drm_funcs, in mantix_probe()
302 ret = drm_panel_of_backlight(&ctx->panel); in mantix_probe()
306 drm_panel_add(&ctx->panel); in mantix_probe()
308 ret = mipi_dsi_attach(dsi); in mantix_probe()
311 drm_panel_remove(&ctx->panel); in mantix_probe()
315 dev_info(dev, "%ux%u@%u %ubpp dsi %udl - ready\n", in mantix_probe()
316 ctx->default_mode->hdisplay, ctx->default_mode->vdisplay, in mantix_probe()
317 drm_mode_vrefresh(ctx->default_mode), in mantix_probe()
318 mipi_dsi_pixel_format_to_bpp(dsi->format), dsi->lanes); in mantix_probe()
323 static void mantix_shutdown(struct mipi_dsi_device *dsi) in mantix_shutdown() argument
325 struct mantix *ctx = mipi_dsi_get_drvdata(dsi); in mantix_shutdown()
327 drm_panel_unprepare(&ctx->panel); in mantix_shutdown()
328 drm_panel_disable(&ctx->panel); in mantix_shutdown()
331 static void mantix_remove(struct mipi_dsi_device *dsi) in mantix_remove() argument
333 struct mantix *ctx = mipi_dsi_get_drvdata(dsi); in mantix_remove()
335 mantix_shutdown(dsi); in mantix_remove()
337 mipi_dsi_detach(dsi); in mantix_remove()
338 drm_panel_remove(&ctx->panel); in mantix_remove()
342 { .compatible = "mantix,mlaf057we51-x", .data = &default_mode_mantix },
360 MODULE_DESCRIPTION("DRM driver for Mantix MLAF057WE51-X MIPI DSI panel");