panel-sharp-lq101r1sx01.c 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475
  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. if (sharp->backlight) {
  77. sharp->backlight->props.power = FB_BLANK_POWERDOWN;
  78. backlight_update_status(sharp->backlight);
  79. }
  80. sharp->enabled = false;
  81. return 0;
  82. }
  83. static int sharp_panel_unprepare(struct drm_panel *panel)
  84. {
  85. struct sharp_panel *sharp = to_sharp_panel(panel);
  86. int err;
  87. if (!sharp->prepared)
  88. return 0;
  89. sharp_wait_frames(sharp, 4);
  90. err = mipi_dsi_dcs_set_display_off(sharp->link1);
  91. if (err < 0)
  92. dev_err(panel->dev, "failed to set display off: %d\n", err);
  93. err = mipi_dsi_dcs_enter_sleep_mode(sharp->link1);
  94. if (err < 0)
  95. dev_err(panel->dev, "failed to enter sleep mode: %d\n", err);
  96. msleep(120);
  97. regulator_disable(sharp->supply);
  98. sharp->prepared = false;
  99. return 0;
  100. }
  101. static int sharp_setup_symmetrical_split(struct mipi_dsi_device *left,
  102. struct mipi_dsi_device *right,
  103. const struct drm_display_mode *mode)
  104. {
  105. int err;
  106. err = mipi_dsi_dcs_set_column_address(left, 0, mode->hdisplay / 2 - 1);
  107. if (err < 0) {
  108. dev_err(&left->dev, "failed to set column address: %d\n", err);
  109. return err;
  110. }
  111. err = mipi_dsi_dcs_set_page_address(left, 0, mode->vdisplay - 1);
  112. if (err < 0) {
  113. dev_err(&left->dev, "failed to set page address: %d\n", err);
  114. return err;
  115. }
  116. err = mipi_dsi_dcs_set_column_address(right, mode->hdisplay / 2,
  117. mode->hdisplay - 1);
  118. if (err < 0) {
  119. dev_err(&right->dev, "failed to set column address: %d\n", err);
  120. return err;
  121. }
  122. err = mipi_dsi_dcs_set_page_address(right, 0, mode->vdisplay - 1);
  123. if (err < 0) {
  124. dev_err(&right->dev, "failed to set page address: %d\n", err);
  125. return err;
  126. }
  127. return 0;
  128. }
  129. static int sharp_panel_prepare(struct drm_panel *panel)
  130. {
  131. struct sharp_panel *sharp = to_sharp_panel(panel);
  132. u8 format = MIPI_DCS_PIXEL_FMT_24BIT;
  133. int err;
  134. if (sharp->prepared)
  135. return 0;
  136. err = regulator_enable(sharp->supply);
  137. if (err < 0)
  138. return err;
  139. /*
  140. * According to the datasheet, the panel needs around 10 ms to fully
  141. * power up. At least another 120 ms is required before exiting sleep
  142. * mode to make sure the panel is ready. Throw in another 20 ms for
  143. * good measure.
  144. */
  145. msleep(150);
  146. err = mipi_dsi_dcs_exit_sleep_mode(sharp->link1);
  147. if (err < 0) {
  148. dev_err(panel->dev, "failed to exit sleep mode: %d\n", err);
  149. goto poweroff;
  150. }
  151. /*
  152. * The MIPI DCS specification mandates this delay only between the
  153. * exit_sleep_mode and enter_sleep_mode commands, so it isn't strictly
  154. * necessary here.
  155. */
  156. /*
  157. msleep(120);
  158. */
  159. /* set left-right mode */
  160. err = sharp_panel_write(sharp, 0x1000, 0x2a);
  161. if (err < 0) {
  162. dev_err(panel->dev, "failed to set left-right mode: %d\n", err);
  163. goto poweroff;
  164. }
  165. /* enable command mode */
  166. err = sharp_panel_write(sharp, 0x1001, 0x01);
  167. if (err < 0) {
  168. dev_err(panel->dev, "failed to enable command mode: %d\n", err);
  169. goto poweroff;
  170. }
  171. err = mipi_dsi_dcs_set_pixel_format(sharp->link1, format);
  172. if (err < 0) {
  173. dev_err(panel->dev, "failed to set pixel format: %d\n", err);
  174. goto poweroff;
  175. }
  176. /*
  177. * TODO: The device supports both left-right and even-odd split
  178. * configurations, but this driver currently supports only the left-
  179. * right split. To support a different mode a mechanism needs to be
  180. * put in place to communicate the configuration back to the DSI host
  181. * controller.
  182. */
  183. err = sharp_setup_symmetrical_split(sharp->link1, sharp->link2,
  184. sharp->mode);
  185. if (err < 0) {
  186. dev_err(panel->dev, "failed to set up symmetrical split: %d\n",
  187. err);
  188. goto poweroff;
  189. }
  190. err = mipi_dsi_dcs_set_display_on(sharp->link1);
  191. if (err < 0) {
  192. dev_err(panel->dev, "failed to set display on: %d\n", err);
  193. goto poweroff;
  194. }
  195. sharp->prepared = true;
  196. /* wait for 6 frames before continuing */
  197. sharp_wait_frames(sharp, 6);
  198. return 0;
  199. poweroff:
  200. regulator_disable(sharp->supply);
  201. return err;
  202. }
  203. static int sharp_panel_enable(struct drm_panel *panel)
  204. {
  205. struct sharp_panel *sharp = to_sharp_panel(panel);
  206. if (sharp->enabled)
  207. return 0;
  208. if (sharp->backlight) {
  209. sharp->backlight->props.power = FB_BLANK_UNBLANK;
  210. backlight_update_status(sharp->backlight);
  211. }
  212. sharp->enabled = true;
  213. return 0;
  214. }
  215. static const struct drm_display_mode default_mode = {
  216. .clock = 278000,
  217. .hdisplay = 2560,
  218. .hsync_start = 2560 + 128,
  219. .hsync_end = 2560 + 128 + 64,
  220. .htotal = 2560 + 128 + 64 + 64,
  221. .vdisplay = 1600,
  222. .vsync_start = 1600 + 4,
  223. .vsync_end = 1600 + 4 + 8,
  224. .vtotal = 1600 + 4 + 8 + 32,
  225. .vrefresh = 60,
  226. };
  227. static int sharp_panel_get_modes(struct drm_panel *panel)
  228. {
  229. struct drm_display_mode *mode;
  230. mode = drm_mode_duplicate(panel->drm, &default_mode);
  231. if (!mode) {
  232. dev_err(panel->drm->dev, "failed to add mode %ux%ux@%u\n",
  233. default_mode.hdisplay, default_mode.vdisplay,
  234. default_mode.vrefresh);
  235. return -ENOMEM;
  236. }
  237. drm_mode_set_name(mode);
  238. drm_mode_probed_add(panel->connector, mode);
  239. panel->connector->display_info.width_mm = 217;
  240. panel->connector->display_info.height_mm = 136;
  241. return 1;
  242. }
  243. static const struct drm_panel_funcs sharp_panel_funcs = {
  244. .disable = sharp_panel_disable,
  245. .unprepare = sharp_panel_unprepare,
  246. .prepare = sharp_panel_prepare,
  247. .enable = sharp_panel_enable,
  248. .get_modes = sharp_panel_get_modes,
  249. };
  250. static const struct of_device_id sharp_of_match[] = {
  251. { .compatible = "sharp,lq101r1sx01", },
  252. { }
  253. };
  254. MODULE_DEVICE_TABLE(of, sharp_of_match);
  255. static int sharp_panel_add(struct sharp_panel *sharp)
  256. {
  257. struct device_node *np;
  258. int err;
  259. sharp->mode = &default_mode;
  260. sharp->supply = devm_regulator_get(&sharp->link1->dev, "power");
  261. if (IS_ERR(sharp->supply))
  262. return PTR_ERR(sharp->supply);
  263. np = of_parse_phandle(sharp->link1->dev.of_node, "backlight", 0);
  264. if (np) {
  265. sharp->backlight = of_find_backlight_by_node(np);
  266. of_node_put(np);
  267. if (!sharp->backlight)
  268. return -EPROBE_DEFER;
  269. }
  270. drm_panel_init(&sharp->base);
  271. sharp->base.funcs = &sharp_panel_funcs;
  272. sharp->base.dev = &sharp->link1->dev;
  273. err = drm_panel_add(&sharp->base);
  274. if (err < 0)
  275. goto put_backlight;
  276. return 0;
  277. put_backlight:
  278. if (sharp->backlight)
  279. put_device(&sharp->backlight->dev);
  280. return err;
  281. }
  282. static void sharp_panel_del(struct sharp_panel *sharp)
  283. {
  284. if (sharp->base.dev)
  285. drm_panel_remove(&sharp->base);
  286. if (sharp->backlight)
  287. put_device(&sharp->backlight->dev);
  288. if (sharp->link2)
  289. put_device(&sharp->link2->dev);
  290. }
  291. static int sharp_panel_probe(struct mipi_dsi_device *dsi)
  292. {
  293. struct mipi_dsi_device *secondary = NULL;
  294. struct sharp_panel *sharp;
  295. struct device_node *np;
  296. int err;
  297. dsi->lanes = 4;
  298. dsi->format = MIPI_DSI_FMT_RGB888;
  299. dsi->mode_flags = MIPI_DSI_MODE_LPM;
  300. /* Find DSI-LINK1 */
  301. np = of_parse_phandle(dsi->dev.of_node, "link2", 0);
  302. if (np) {
  303. secondary = of_find_mipi_dsi_device_by_node(np);
  304. of_node_put(np);
  305. if (!secondary)
  306. return -EPROBE_DEFER;
  307. }
  308. /* register a panel for only the DSI-LINK1 interface */
  309. if (secondary) {
  310. sharp = devm_kzalloc(&dsi->dev, sizeof(*sharp), GFP_KERNEL);
  311. if (!sharp) {
  312. put_device(&secondary->dev);
  313. return -ENOMEM;
  314. }
  315. mipi_dsi_set_drvdata(dsi, sharp);
  316. sharp->link2 = secondary;
  317. sharp->link1 = dsi;
  318. err = sharp_panel_add(sharp);
  319. if (err < 0) {
  320. put_device(&secondary->dev);
  321. return err;
  322. }
  323. }
  324. err = mipi_dsi_attach(dsi);
  325. if (err < 0) {
  326. if (secondary)
  327. sharp_panel_del(sharp);
  328. return err;
  329. }
  330. return 0;
  331. }
  332. static int sharp_panel_remove(struct mipi_dsi_device *dsi)
  333. {
  334. struct sharp_panel *sharp = mipi_dsi_get_drvdata(dsi);
  335. int err;
  336. /* only detach from host for the DSI-LINK2 interface */
  337. if (!sharp) {
  338. mipi_dsi_detach(dsi);
  339. return 0;
  340. }
  341. err = sharp_panel_disable(&sharp->base);
  342. if (err < 0)
  343. dev_err(&dsi->dev, "failed to disable panel: %d\n", err);
  344. err = mipi_dsi_detach(dsi);
  345. if (err < 0)
  346. dev_err(&dsi->dev, "failed to detach from DSI host: %d\n", err);
  347. drm_panel_detach(&sharp->base);
  348. sharp_panel_del(sharp);
  349. return 0;
  350. }
  351. static void sharp_panel_shutdown(struct mipi_dsi_device *dsi)
  352. {
  353. struct sharp_panel *sharp = mipi_dsi_get_drvdata(dsi);
  354. /* nothing to do for DSI-LINK2 */
  355. if (!sharp)
  356. return;
  357. sharp_panel_disable(&sharp->base);
  358. }
  359. static struct mipi_dsi_driver sharp_panel_driver = {
  360. .driver = {
  361. .name = "panel-sharp-lq101r1sx01",
  362. .of_match_table = sharp_of_match,
  363. },
  364. .probe = sharp_panel_probe,
  365. .remove = sharp_panel_remove,
  366. .shutdown = sharp_panel_shutdown,
  367. };
  368. module_mipi_dsi_driver(sharp_panel_driver);
  369. MODULE_AUTHOR("Thierry Reding <treding@nvidia.com>");
  370. MODULE_DESCRIPTION("Sharp LQ101R1SX01 panel driver");
  371. MODULE_LICENSE("GPL v2");