s6e8ax0.c 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. /*
  2. * Copyright (C) 2012 Samsung Electronics
  3. *
  4. * Author: Donghwa Lee <dh09.lee@samsung.com>
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU General Public License as
  8. * published by the Free Software Foundation; either version 2 of
  9. * the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program; if not, write to the Free Software
  18. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  19. * MA 02111-1307 USA
  20. */
  21. #include <common.h>
  22. #include <asm/arch/mipi_dsim.h>
  23. #include "exynos_mipi_dsi_lowlevel.h"
  24. #include "exynos_mipi_dsi_common.h"
  25. static void s6e8ax0_panel_cond(struct mipi_dsim_device *dsim_dev)
  26. {
  27. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  28. int reverse = dsim_dev->dsim_lcd_dev->reverse_panel;
  29. const unsigned char data_to_send[] = {
  30. 0xf8, 0x3d, 0x35, 0x00, 0x00, 0x00, 0x8d, 0x00, 0x4c,
  31. 0x6e, 0x10, 0x27, 0x7d, 0x3f, 0x10, 0x00, 0x00, 0x20,
  32. 0x04, 0x08, 0x6e, 0x00, 0x00, 0x00, 0x02, 0x08, 0x08,
  33. 0x23, 0x23, 0xc0, 0xc8, 0x08, 0x48, 0xc1, 0x00, 0xc3,
  34. 0xff, 0xff, 0xc8
  35. };
  36. const unsigned char data_to_send_reverse[] = {
  37. 0xf8, 0x19, 0x35, 0x00, 0x00, 0x00, 0x93, 0x00, 0x3c,
  38. 0x7d, 0x08, 0x27, 0x7d, 0x3f, 0x00, 0x00, 0x00, 0x20,
  39. 0x04, 0x08, 0x6e, 0x00, 0x00, 0x00, 0x02, 0x08, 0x08,
  40. 0x23, 0x23, 0xc0, 0xc1, 0x01, 0x41, 0xc1, 0x00, 0xc1,
  41. 0xf6, 0xf6, 0xc1
  42. };
  43. if (reverse) {
  44. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_LONG_WRITE,
  45. (unsigned int)data_to_send_reverse,
  46. ARRAY_SIZE(data_to_send_reverse));
  47. } else {
  48. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_LONG_WRITE,
  49. (unsigned int)data_to_send, ARRAY_SIZE(data_to_send));
  50. }
  51. }
  52. static void s6e8ax0_display_cond(struct mipi_dsim_device *dsim_dev)
  53. {
  54. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  55. const unsigned char data_to_send[] = {
  56. 0xf2, 0x80, 0x03, 0x0d
  57. };
  58. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_LONG_WRITE,
  59. (unsigned int)data_to_send,
  60. ARRAY_SIZE(data_to_send));
  61. }
  62. static void s6e8ax0_gamma_cond(struct mipi_dsim_device *dsim_dev)
  63. {
  64. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  65. /* 7500K 2.2 Set : 30cd */
  66. const unsigned char data_to_send[] = {
  67. 0xfa, 0x01, 0x60, 0x10, 0x60, 0xf5, 0x00, 0xff, 0xad,
  68. 0xaf, 0xba, 0xc3, 0xd8, 0xc5, 0x9f, 0xc6, 0x9e, 0xc1,
  69. 0xdc, 0xc0, 0x00, 0x61, 0x00, 0x5a, 0x00, 0x74,
  70. };
  71. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_LONG_WRITE,
  72. (unsigned int)data_to_send,
  73. ARRAY_SIZE(data_to_send));
  74. }
  75. static void s6e8ax0_gamma_update(struct mipi_dsim_device *dsim_dev)
  76. {
  77. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  78. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_SHORT_WRITE_PARAM, 0xf7, 0x3);
  79. }
  80. static void s6e8ax0_etc_source_control(struct mipi_dsim_device *dsim_dev)
  81. {
  82. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  83. const unsigned char data_to_send[] = {
  84. 0xf6, 0x00, 0x02, 0x00
  85. };
  86. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_LONG_WRITE,
  87. (unsigned int)data_to_send,
  88. ARRAY_SIZE(data_to_send));
  89. }
  90. static void s6e8ax0_etc_pentile_control(struct mipi_dsim_device *dsim_dev)
  91. {
  92. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  93. const unsigned char data_to_send[] = {
  94. 0xb6, 0x0c, 0x02, 0x03, 0x32, 0xff, 0x44, 0x44, 0xc0,
  95. 0x00
  96. };
  97. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_LONG_WRITE,
  98. (unsigned int)data_to_send,
  99. ARRAY_SIZE(data_to_send));
  100. }
  101. static void s6e8ax0_etc_mipi_control1(struct mipi_dsim_device *dsim_dev)
  102. {
  103. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  104. const unsigned char data_to_send[] = {
  105. 0xe1, 0x10, 0x1c, 0x17, 0x08, 0x1d
  106. };
  107. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_LONG_WRITE,
  108. (unsigned int)data_to_send,
  109. ARRAY_SIZE(data_to_send));
  110. }
  111. static void s6e8ax0_etc_mipi_control2(struct mipi_dsim_device *dsim_dev)
  112. {
  113. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  114. const unsigned char data_to_send[] = {
  115. 0xe2, 0xed, 0x07, 0xc3, 0x13, 0x0d, 0x03
  116. };
  117. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_LONG_WRITE,
  118. (unsigned int)data_to_send,
  119. ARRAY_SIZE(data_to_send));
  120. }
  121. static void s6e8ax0_etc_power_control(struct mipi_dsim_device *dsim_dev)
  122. {
  123. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  124. const unsigned char data_to_send[] = {
  125. 0xf4, 0xcf, 0x0a, 0x12, 0x10, 0x19, 0x33, 0x02
  126. };
  127. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_LONG_WRITE,
  128. (unsigned int)data_to_send, ARRAY_SIZE(data_to_send));
  129. }
  130. static void s6e8ax0_etc_mipi_control3(struct mipi_dsim_device *dsim_dev)
  131. {
  132. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  133. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_SHORT_WRITE_PARAM, 0xe3, 0x40);
  134. }
  135. static void s6e8ax0_etc_mipi_control4(struct mipi_dsim_device *dsim_dev)
  136. {
  137. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  138. const unsigned char data_to_send[] = {
  139. 0xe4, 0x00, 0x00, 0x14, 0x80, 0x00, 0x00, 0x00
  140. };
  141. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_LONG_WRITE,
  142. (unsigned int)data_to_send, ARRAY_SIZE(data_to_send));
  143. }
  144. static void s6e8ax0_elvss_set(struct mipi_dsim_device *dsim_dev)
  145. {
  146. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  147. const unsigned char data_to_send[] = {
  148. 0xb1, 0x04, 0x00
  149. };
  150. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_LONG_WRITE,
  151. (unsigned int)data_to_send,
  152. ARRAY_SIZE(data_to_send));
  153. }
  154. static void s6e8ax0_display_on(struct mipi_dsim_device *dsim_dev)
  155. {
  156. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  157. ops->cmd_write(dsim_dev,
  158. MIPI_DSI_DCS_SHORT_WRITE, 0x29, 0x00);
  159. }
  160. static void s6e8ax0_sleep_out(struct mipi_dsim_device *dsim_dev)
  161. {
  162. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  163. ops->cmd_write(dsim_dev,
  164. MIPI_DSI_DCS_SHORT_WRITE, 0x11, 0x00);
  165. }
  166. static void s6e8ax0_apply_level1_key(struct mipi_dsim_device *dsim_dev)
  167. {
  168. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  169. const unsigned char data_to_send[] = {
  170. 0xf0, 0x5a, 0x5a
  171. };
  172. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_LONG_WRITE,
  173. (unsigned int)data_to_send, ARRAY_SIZE(data_to_send));
  174. }
  175. static void s6e8ax0_apply_mtp_key(struct mipi_dsim_device *dsim_dev)
  176. {
  177. struct mipi_dsim_master_ops *ops = dsim_dev->master_ops;
  178. const unsigned char data_to_send[] = {
  179. 0xf1, 0x5a, 0x5a
  180. };
  181. ops->cmd_write(dsim_dev, MIPI_DSI_DCS_LONG_WRITE,
  182. (unsigned int)data_to_send, ARRAY_SIZE(data_to_send));
  183. }
  184. static void s6e8ax0_panel_init(struct mipi_dsim_device *dsim_dev)
  185. {
  186. /*
  187. * in case of setting gamma and panel condition at first,
  188. * it shuold be setting like below.
  189. * set_gamma() -> set_panel_condition()
  190. */
  191. s6e8ax0_apply_level1_key(dsim_dev);
  192. s6e8ax0_apply_mtp_key(dsim_dev);
  193. s6e8ax0_sleep_out(dsim_dev);
  194. mdelay(5);
  195. s6e8ax0_panel_cond(dsim_dev);
  196. s6e8ax0_display_cond(dsim_dev);
  197. s6e8ax0_gamma_cond(dsim_dev);
  198. s6e8ax0_gamma_update(dsim_dev);
  199. s6e8ax0_etc_source_control(dsim_dev);
  200. s6e8ax0_elvss_set(dsim_dev);
  201. s6e8ax0_etc_pentile_control(dsim_dev);
  202. s6e8ax0_etc_mipi_control1(dsim_dev);
  203. s6e8ax0_etc_mipi_control2(dsim_dev);
  204. s6e8ax0_etc_power_control(dsim_dev);
  205. s6e8ax0_etc_mipi_control3(dsim_dev);
  206. s6e8ax0_etc_mipi_control4(dsim_dev);
  207. }
  208. static int s6e8ax0_panel_set(struct mipi_dsim_device *dsim_dev)
  209. {
  210. s6e8ax0_panel_init(dsim_dev);
  211. return 0;
  212. }
  213. static void s6e8ax0_display_enable(struct mipi_dsim_device *dsim_dev)
  214. {
  215. s6e8ax0_display_on(dsim_dev);
  216. }
  217. static struct mipi_dsim_lcd_driver s6e8ax0_dsim_ddi_driver = {
  218. .name = "s6e8ax0",
  219. .id = -1,
  220. .mipi_panel_init = s6e8ax0_panel_set,
  221. .mipi_display_on = s6e8ax0_display_enable,
  222. };
  223. void s6e8ax0_init(void)
  224. {
  225. exynos_mipi_dsi_register_lcd_driver(&s6e8ax0_dsim_ddi_driver);
  226. }