panel-sharp-lq101r1sx01.c 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450
  1. /*
  2. * Copyright (C) 2014 NVIDIA Corporation
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License version 2 as
  6. * published by the Free Software Foundation.
  7. */
  8. #include <linux/backlight.h>
  9. #include <linux/gpio/consumer.h>
  10. #include <linux/module.h>
  11. #include <linux/of.h>
  12. #include <linux/regulator/consumer.h>
  13. #include <drm/drmP.h>
  14. #include <drm/drm_crtc.h>
  15. #include <drm/drm_mipi_dsi.h>
  16. #include <drm/drm_panel.h>
  17. #include <video/mipi_display.h>
  18. struct sharp_panel {
  19. struct drm_panel base;
  20. /* the datasheet refers to them as DSI-LINK1 and DSI-LINK2 */
  21. struct mipi_dsi_device *link1;
  22. struct mipi_dsi_device *link2;
  23. struct backlight_device *backlight;
  24. struct regulator *supply;
  25. bool prepared;
  26. bool enabled;
  27. const struct drm_display_mode *mode;
  28. };
  29. static inline struct sharp_panel *to_sharp_panel(struct drm_panel *panel)
  30. {
  31. return container_of(panel, struct sharp_panel, base);
  32. }
  33. static void sharp_wait_frames(struct sharp_panel *sharp, unsigned int frames)
  34. {
  35. unsigned int refresh = drm_mode_vrefresh(sharp->mode);
  36. if (WARN_ON(frames > refresh))
  37. return;
  38. msleep(1000 / (refresh / frames));
  39. }
  40. static int sharp_panel_write(struct sharp_panel *sharp, u16 offset, u8 value)
  41. {
  42. u8 payload[3] = { offset >> 8, offset & 0xff, value };
  43. struct mipi_dsi_device *dsi = sharp->link1;
  44. ssize_t err;
  45. err = mipi_dsi_generic_write(dsi, payload, sizeof(payload));
  46. if (err < 0) {
  47. dev_err(&dsi->dev, "failed to write %02x to %04x: %zd\n",
  48. value, offset, err);
  49. return err;
  50. }
  51. err = mipi_dsi_dcs_nop(dsi);
  52. if (err < 0) {
  53. dev_err(&dsi->dev, "failed to send DCS nop: %zd\n", err);
  54. return err;
  55. }
  56. usleep_range(10, 20);
  57. return 0;
  58. }
  59. static __maybe_unused int sharp_panel_read(struct sharp_panel *sharp,
  60. u16 offset, u8 *value)
  61. {
  62. ssize_t err;
  63. cpu_to_be16s(&offset);
  64. err = mipi_dsi_generic_read(sharp->link1, &offset, sizeof(offset),
  65. value, sizeof(*value));
  66. if (err < 0)
  67. dev_err(&sharp->link1->dev, "failed to read from %04x: %zd\n",
  68. offset, err);
  69. return err;
  70. }
  71. static int sharp_panel_disable(struct drm_panel *panel)
  72. {
  73. struct sharp_panel *sharp = to_sharp_panel(panel);
  74. if (!sharp->enabled)
  75. return 0;
  76. backlight_disable(sharp->backlight);
  77. sharp->enabled = false;
  78. return 0;
  79. }
  80. static int sharp_panel_unprepare(struct drm_panel *panel)
  81. {
  82. struct sharp_panel *sharp = to_sharp_panel(panel);
  83. int err;
  84. if (!sharp->prepared)
  85. return 0;
  86. sharp_wait_frames(sharp, 4);
  87. err = mipi_dsi_dcs_set_display_off(sharp->link1);
  88. if (err < 0)
  89. dev_err(panel->dev, "failed to set display off: %d\n", err);
  90. err = mipi_dsi_dcs_enter_sleep_mode(sharp->link1);
  91. if (err < 0)
  92. dev_err(panel->dev, "failed to enter sleep mode: %d\n", err);
  93. msleep(120);
  94. regulator_disable(sharp->supply);
  95. sharp->prepared = false;
  96. return 0;
  97. }
  98. static int sharp_setup_symmetrical_split(struct mipi_dsi_device *left,
  99. struct mipi_dsi_device *right,
  100. const struct drm_display_mode *mode)
  101. {
  102. int err;
  103. err = mipi_dsi_dcs_set_column_address(left, 0, mode->hdisplay / 2 - 1);
  104. if (err < 0) {
  105. dev_err(&left->dev, "failed to set column address: %d\n", err);
  106. return err;
  107. }
  108. err = mipi_dsi_dcs_set_page_address(left, 0, mode->vdisplay - 1);
  109. if (err < 0) {
  110. dev_err(&left->dev, "failed to set page address: %d\n", err);
  111. return err;
  112. }
  113. err = mipi_dsi_dcs_set_column_address(right, mode->hdisplay / 2,
  114. mode->hdisplay - 1);
  115. if (err < 0) {
  116. dev_err(&right->dev, "failed to set column address: %d\n", err);
  117. return err;
  118. }
  119. err = mipi_dsi_dcs_set_page_address(right, 0, mode->vdisplay - 1);
  120. if (err < 0) {
  121. dev_err(&right->dev, "failed to set page address: %d\n", err);
  122. return err;
  123. }
  124. return 0;
  125. }
  126. static int sharp_panel_prepare(struct drm_panel *panel)
  127. {
  128. struct sharp_panel *sharp = to_sharp_panel(panel);
  129. u8 format = MIPI_DCS_PIXEL_FMT_24BIT;
  130. int err;
  131. if (sharp->prepared)
  132. return 0;
  133. err = regulator_enable(sharp->supply);
  134. if (err < 0)
  135. return err;
  136. /*
  137. * According to the datasheet, the panel needs around 10 ms to fully
  138. * power up. At least another 120 ms is required before exiting sleep
  139. * mode to make sure the panel is ready. Throw in another 20 ms for
  140. * good measure.
  141. */
  142. msleep(150);
  143. err = mipi_dsi_dcs_exit_sleep_mode(sharp->link1);
  144. if (err < 0) {
  145. dev_err(panel->dev, "failed to exit sleep mode: %d\n", err);
  146. goto poweroff;
  147. }
  148. /*
  149. * The MIPI DCS specification mandates this delay only between the
  150. * exit_sleep_mode and enter_sleep_mode commands, so it isn't strictly
  151. * necessary here.
  152. */
  153. /*
  154. msleep(120);
  155. */
  156. /* set left-right mode */
  157. err = sharp_panel_write(sharp, 0x1000, 0x2a);
  158. if (err < 0) {
  159. dev_err(panel->dev, "failed to set left-right mode: %d\n", err);
  160. goto poweroff;
  161. }
  162. /* enable command mode */
  163. err = sharp_panel_write(sharp, 0x1001, 0x01);
  164. if (err < 0) {
  165. dev_err(panel->dev, "failed to enable command mode: %d\n", err);
  166. goto poweroff;
  167. }
  168. err = mipi_dsi_dcs_set_pixel_format(sharp->link1, format);
  169. if (err < 0) {
  170. dev_err(panel->dev, "failed to set pixel format: %d\n", err);
  171. goto poweroff;
  172. }
  173. /*
  174. * TODO: The device supports both left-right and even-odd split
  175. * configurations, but this driver currently supports only the left-
  176. * right split. To support a different mode a mechanism needs to be
  177. * put in place to communicate the configuration back to the DSI host
  178. * controller.
  179. */
  180. err = sharp_setup_symmetrical_split(sharp->link1, sharp->link2,
  181. sharp->mode);
  182. if (err < 0) {
  183. dev_err(panel->dev, "failed to set up symmetrical split: %d\n",
  184. err);
  185. goto poweroff;
  186. }
  187. err = mipi_dsi_dcs_set_display_on(sharp->link1);
  188. if (err < 0) {
  189. dev_err(panel->dev, "failed to set display on: %d\n", err);
  190. goto poweroff;
  191. }
  192. sharp->prepared = true;
  193. /* wait for 6 frames before continuing */
  194. sharp_wait_frames(sharp, 6);
  195. return 0;
  196. poweroff:
  197. regulator_disable(sharp->supply);
  198. return err;
  199. }
  200. static int sharp_panel_enable(struct drm_panel *panel)
  201. {
  202. struct sharp_panel *sharp = to_sharp_panel(panel);
  203. if (sharp->enabled)
  204. return 0;
  205. backlight_enable(sharp->backlight);
  206. sharp->enabled = true;
  207. return 0;
  208. }
  209. static const struct drm_display_mode default_mode = {
  210. .clock = 278000,
  211. .hdisplay = 2560,
  212. .hsync_start = 2560 + 128,
  213. .hsync_end = 2560 + 128 + 64,
  214. .htotal = 2560 + 128 + 64 + 64,
  215. .vdisplay = 1600,
  216. .vsync_start = 1600 + 4,
  217. .vsync_end = 1600 + 4 + 8,
  218. .vtotal = 1600 + 4 + 8 + 32,
  219. .vrefresh = 60,
  220. };
  221. static int sharp_panel_get_modes(struct drm_panel *panel)
  222. {
  223. struct drm_display_mode *mode;
  224. mode = drm_mode_duplicate(panel->drm, &default_mode);
  225. if (!mode) {
  226. dev_err(panel->drm->dev, "failed to add mode %ux%ux@%u\n",
  227. default_mode.hdisplay, default_mode.vdisplay,
  228. default_mode.vrefresh);
  229. return -ENOMEM;
  230. }
  231. drm_mode_set_name(mode);
  232. drm_mode_probed_add(panel->connector, mode);
  233. panel->connector->display_info.width_mm = 217;
  234. panel->connector->display_info.height_mm = 136;
  235. return 1;
  236. }
  237. static const struct drm_panel_funcs sharp_panel_funcs = {
  238. .disable = sharp_panel_disable,
  239. .unprepare = sharp_panel_unprepare,
  240. .prepare = sharp_panel_prepare,
  241. .enable = sharp_panel_enable,
  242. .get_modes = sharp_panel_get_modes,
  243. };
  244. static const struct of_device_id sharp_of_match[] = {
  245. { .compatible = "sharp,lq101r1sx01", },
  246. { }
  247. };
  248. MODULE_DEVICE_TABLE(of, sharp_of_match);
  249. static int sharp_panel_add(struct sharp_panel *sharp)
  250. {
  251. struct device *dev = &sharp->link1->dev;
  252. sharp->mode = &default_mode;
  253. sharp->supply = devm_regulator_get(&sharp->link1->dev, "power");
  254. if (IS_ERR(sharp->supply))
  255. return PTR_ERR(sharp->supply);
  256. sharp->backlight = devm_of_find_backlight(dev);
  257. if (IS_ERR(sharp->backlight))
  258. return PTR_ERR(sharp->backlight);
  259. drm_panel_init(&sharp->base);
  260. sharp->base.funcs = &sharp_panel_funcs;
  261. sharp->base.dev = &sharp->link1->dev;
  262. return drm_panel_add(&sharp->base);
  263. }
  264. static void sharp_panel_del(struct sharp_panel *sharp)
  265. {
  266. if (sharp->base.dev)
  267. drm_panel_remove(&sharp->base);
  268. if (sharp->link2)
  269. put_device(&sharp->link2->dev);
  270. }
  271. static int sharp_panel_probe(struct mipi_dsi_device *dsi)
  272. {
  273. struct mipi_dsi_device *secondary = NULL;
  274. struct sharp_panel *sharp;
  275. struct device_node *np;
  276. int err;
  277. dsi->lanes = 4;
  278. dsi->format = MIPI_DSI_FMT_RGB888;
  279. dsi->mode_flags = MIPI_DSI_MODE_LPM;
  280. /* Find DSI-LINK1 */
  281. np = of_parse_phandle(dsi->dev.of_node, "link2", 0);
  282. if (np) {
  283. secondary = of_find_mipi_dsi_device_by_node(np);
  284. of_node_put(np);
  285. if (!secondary)
  286. return -EPROBE_DEFER;
  287. }
  288. /* register a panel for only the DSI-LINK1 interface */
  289. if (secondary) {
  290. sharp = devm_kzalloc(&dsi->dev, sizeof(*sharp), GFP_KERNEL);
  291. if (!sharp) {
  292. put_device(&secondary->dev);
  293. return -ENOMEM;
  294. }
  295. mipi_dsi_set_drvdata(dsi, sharp);
  296. sharp->link2 = secondary;
  297. sharp->link1 = dsi;
  298. err = sharp_panel_add(sharp);
  299. if (err < 0) {
  300. put_device(&secondary->dev);
  301. return err;
  302. }
  303. }
  304. err = mipi_dsi_attach(dsi);
  305. if (err < 0) {
  306. if (secondary)
  307. sharp_panel_del(sharp);
  308. return err;
  309. }
  310. return 0;
  311. }
  312. static int sharp_panel_remove(struct mipi_dsi_device *dsi)
  313. {
  314. struct sharp_panel *sharp = mipi_dsi_get_drvdata(dsi);
  315. int err;
  316. /* only detach from host for the DSI-LINK2 interface */
  317. if (!sharp) {
  318. mipi_dsi_detach(dsi);
  319. return 0;
  320. }
  321. err = sharp_panel_disable(&sharp->base);
  322. if (err < 0)
  323. dev_err(&dsi->dev, "failed to disable panel: %d\n", err);
  324. err = mipi_dsi_detach(dsi);
  325. if (err < 0)
  326. dev_err(&dsi->dev, "failed to detach from DSI host: %d\n", err);
  327. sharp_panel_del(sharp);
  328. return 0;
  329. }
  330. static void sharp_panel_shutdown(struct mipi_dsi_device *dsi)
  331. {
  332. struct sharp_panel *sharp = mipi_dsi_get_drvdata(dsi);
  333. /* nothing to do for DSI-LINK2 */
  334. if (!sharp)
  335. return;
  336. sharp_panel_disable(&sharp->base);
  337. }
  338. static struct mipi_dsi_driver sharp_panel_driver = {
  339. .driver = {
  340. .name = "panel-sharp-lq101r1sx01",
  341. .of_match_table = sharp_of_match,
  342. },
  343. .probe = sharp_panel_probe,
  344. .remove = sharp_panel_remove,
  345. .shutdown = sharp_panel_shutdown,
  346. };
  347. module_mipi_dsi_driver(sharp_panel_driver);
  348. MODULE_AUTHOR("Thierry Reding <treding@nvidia.com>");
  349. MODULE_DESCRIPTION("Sharp LQ101R1SX01 panel driver");
  350. MODULE_LICENSE("GPL v2");