panel_st77916.c 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795
  1. /*
  2. * Copyright (c) 2020 Actions Technology Co., Ltd
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #include <sys/byteorder.h>
  7. #include "panel_st77916.h"
  8. #include "panel_device.h"
  9. /*********************
  10. * DEFINES
  11. *********************/
  12. /**********************
  13. * TYPEDEFS
  14. **********************/
  15. /**********************
  16. * STATIC PROTOTYPES
  17. **********************/
  18. /**********************
  19. * STATIC VARIABLES
  20. **********************/
  21. /**********************
  22. * MACROS
  23. **********************/
  24. /**********************
  25. * FUNCTIONS
  26. **********************/
  27. static void _panel_transmit(const struct device *dev, uint32_t cmd,
  28. const uint8_t *tx_data, size_t tx_count)
  29. {
  30. struct lcd_panel_data *data = dev->data;
  31. //assert(data->transfering == 0);
  32. display_controller_write_config(data->lcdc_dev, ST77916_WR_CMD(cmd), tx_data, tx_count);
  33. }
  34. static inline void _panel_transmit_cmd(const struct device *dev, uint32_t cmd)
  35. {
  36. _panel_transmit(dev, cmd, NULL, 0);
  37. }
  38. static inline void _panel_transmit_p1(const struct device *dev, uint32_t cmd, uint8_t tx_data)
  39. {
  40. _panel_transmit(dev, cmd, &tx_data, 1);
  41. }
  42. #ifdef DMG_LCM // DMG LCM
  43. static void _panel_transmit_p2(const struct device *dev, uint32_t cmd, uint8_t data1, uint8_t data2)
  44. {
  45. uint8_t data_array[2] = {
  46. data1,
  47. data2,
  48. };
  49. _panel_transmit(dev, cmd, data_array, 2);
  50. }
  51. #endif
  52. static int _panel_set_brightness(const struct device *dev, uint8_t brightness)
  53. {
  54. _panel_transmit_p1(dev, DDIC_CMD_WRDISBV, brightness);
  55. return 0;
  56. }
  57. static int _panel_set_mem_area(const struct device *dev, uint16_t x, uint16_t y, uint16_t w,
  58. uint16_t h)
  59. {
  60. uint16_t cmd_data[2];
  61. x += CONFIG_PANEL_MEM_OFFSET_X; // add 12 pixel offset ?
  62. y += CONFIG_PANEL_MEM_OFFSET_Y;
  63. cmd_data[0] = sys_cpu_to_be16(x);
  64. cmd_data[1] = sys_cpu_to_be16(x + w - 1);
  65. _panel_transmit(dev, DDIC_CMD_CASET, (uint8_t *)&cmd_data[0], 4);
  66. cmd_data[0] = sys_cpu_to_be16(y);
  67. cmd_data[1] = sys_cpu_to_be16(y + h - 1);
  68. _panel_transmit(dev, DDIC_CMD_RASET, (uint8_t *)&cmd_data[0], 4);
  69. return 0;
  70. }
  71. #if 0
  72. static void _panel_exit_sleep(const struct device *dev)
  73. {
  74. struct lcd_panel_data *data = dev->data;
  75. _panel_transmit_cmd(dev, DDIC_CMD_SLPOUT);
  76. k_msleep(120);
  77. data->in_sleep = 0;
  78. // _panel_transmit_cmd(dev, 0xFE);
  79. // _panel_transmit_cmd(dev, 0xEF);
  80. // _panel_transmit_cmd(dev, 0x11);
  81. // k_msleep(120);
  82. // _panel_transmit_cmd(dev, 0x29);
  83. //printk("st77916 panel exit sleep \r\n ");
  84. }
  85. #endif
  86. static int _panel_blanking_on(const struct device *dev)
  87. {
  88. //printk("st77916 panel blanking on \r\n ");
  89. //_panel_transmit_cmd(dev, DDIC_CMD_DISPOFF);
  90. //_panel_transmit_cmd(dev, DDIC_CMD_SLPIN);
  91. return 0;
  92. }
  93. static int _panel_blanking_off(const struct device *dev)
  94. {
  95. //struct lcd_panel_data *data = dev->data;
  96. //printk("st77916 panel blanking off \r\n ");
  97. //if (data->in_sleep)
  98. // _panel_exit_sleep(dev);
  99. //_panel_transmit_cmd(dev, DDIC_CMD_DISPON);
  100. k_msleep(80);
  101. return 0;
  102. }
  103. static int _panel_lowpower_enter(const struct device *dev)
  104. {
  105. //printk("st77916 panel lowpower enter \r\n ");
  106. //_panel_transmit_p1(dev, 0xFE, 0x01);
  107. /* 0x01 60Hz, 0x41 30Hz, 0x43 15Hz, 0x4B 5Hz, 0x7B 1Hz */
  108. //_panel_transmit_p1(dev, 0x29, 0x4B);
  109. //_panel_transmit_p1(dev, 0xFE, 0x00);
  110. return 0;
  111. }
  112. static int _panel_lowpower_exit(const struct device *dev)
  113. {
  114. //printk("st77916 panel lowpower exit \r\n ");
  115. //_panel_transmit_p1(dev, 0xFE, 0x01);
  116. //_panel_transmit_p1(dev, 0x29, 0x01);
  117. //_panel_transmit_p1(dev, 0xFE, 0x00);
  118. return 0;
  119. }
  120. //static void _panel_init_te(const struct device *dev)
  121. //{
  122. // const struct lcd_panel_config *config = dev->config;
  123. // if (config->videomode.flags & (DISPLAY_FLAGS_TE_HIGH | DISPLAY_FLAGS_TE_LOW)) {
  124. // uint8_t tmp[2];
  125. // sys_put_be16(CONFIG_PANEL_TE_SCANLINE, tmp);
  126. // _panel_transmit(dev, DDIC_CMD_STESL, tmp, 2);
  127. // tmp[0] = 0x02;
  128. // _panel_transmit(dev, DDIC_CMD_TEON, tmp, 1);
  129. // } else {
  130. // _panel_transmit(dev, DDIC_CMD_TEOFF, NULL, 0);
  131. // }
  132. //}
  133. static int _panel_init(const struct device *dev)
  134. {
  135. /* Sleep Out */
  136. //_panel_exit_sleep(dev);
  137. // internal reg enable
  138. //_panel_transmit(dev, DDIC_CMD_INTERREG_EN1, NULL, 0);
  139. //_panel_transmit(dev, DDIC_CMD_INTERREG_EN2, NULL, 0);
  140. printk("st77916 panel_init \r\n ");
  141. #ifdef DMG_LCM // DMG LCM
  142. _panel_transmit_p1(dev, 0xf0, 0x08);
  143. _panel_transmit_p1(dev, 0xF2, 0x08);
  144. _panel_transmit_p1(dev, 0x9B, 0x51);
  145. _panel_transmit_p1(dev, 0x86, 0x53);
  146. _panel_transmit_p1(dev, 0xF2, 0x80);
  147. _panel_transmit_p1(dev, 0xF0, 0x00);
  148. _panel_transmit_p1(dev, 0xF0, 0x01);
  149. _panel_transmit_p1(dev, 0xF1, 0x01);
  150. _panel_transmit_p1(dev, 0xB0, 0x54);
  151. _panel_transmit_p1(dev, 0xB1, 0x3F);
  152. _panel_transmit_p1(dev, 0xB2, 0x2A);
  153. _panel_transmit_p1(dev, 0xB4, 0x46);
  154. _panel_transmit_p1(dev, 0xB5, 0x34);
  155. _panel_transmit_p1(dev, 0xB6, 0xD5);
  156. _panel_transmit_p1(dev, 0xB7, 0x30);
  157. //_panel_transmit_p1(dev, 0xB8, 0x04);
  158. _panel_transmit_p1(dev, 0xBA, 0x00);
  159. _panel_transmit_p1(dev, 0xBB, 0x08);
  160. _panel_transmit_p1(dev, 0xBC, 0x08);
  161. _panel_transmit_p1(dev, 0xBD, 0x00);
  162. _panel_transmit_p1(dev, 0xC0, 0x80);
  163. _panel_transmit_p1(dev, 0xC1, 0x10);
  164. _panel_transmit_p1(dev, 0xC2, 0x37);
  165. _panel_transmit_p1(dev, 0xC3, 0x80);
  166. _panel_transmit_p1(dev, 0xC4, 0x10);
  167. _panel_transmit_p1(dev, 0xC5, 0x37);
  168. _panel_transmit_p1(dev, 0xC6, 0xA9);
  169. _panel_transmit_p1(dev, 0xC7, 0x41);
  170. _panel_transmit_p1(dev, 0xC8, 0x51);
  171. _panel_transmit_p1(dev, 0xC9, 0xA9);
  172. _panel_transmit_p1(dev, 0xCA, 0x41);
  173. _panel_transmit_p1(dev, 0xCB, 0x51);
  174. _panel_transmit_p1(dev, 0xD0, 0x91);
  175. _panel_transmit_p1(dev, 0xD1, 0x68);
  176. _panel_transmit_p1(dev, 0xD2, 0x69);
  177. const uint8_t data_0xf5[] = {
  178. 0x00,
  179. 0xA5,
  180. };
  181. _panel_transmit(dev, 0xF5, data_0xf5, sizeof(data_0xf5));
  182. _panel_transmit_p1(dev, 0xDD, 0x3F);
  183. _panel_transmit_p1(dev, 0xDE, 0x3F);
  184. _panel_transmit_p1(dev, 0xF1, 0x10);
  185. _panel_transmit_p1(dev, 0xF0, 0x00);
  186. _panel_transmit_p1(dev, 0xF0, 0x02);
  187. const uint8_t data_0xe0[] = {
  188. 0xF0, 0x06, 0x0B, 0x09, 0x09, 0x16, 0x32, 0x44, 0x4A, 0x37, 0x13, 0x13, 0x2E, 0x34,
  189. };
  190. _panel_transmit(dev, 0xE0, data_0xe0, sizeof(data_0xe0));
  191. const uint8_t data_0xe1[] = {
  192. 0xF0, 0x06, 0x0B, 0x09, 0x08, 0x05, 0x32, 0x33, 0x49, 0x17, 0x13, 0x13, 0x2E, 0x34,
  193. };
  194. _panel_transmit(dev, 0xE1, data_0xe1, sizeof(data_0xe1));
  195. _panel_transmit_p1(dev, 0xF0, 0x10);
  196. _panel_transmit_p1(dev, 0xF3, 0x10);
  197. _panel_transmit_p1(dev, 0xE0, 0x0A);
  198. _panel_transmit_p1(dev, 0xE1, 0x00);
  199. _panel_transmit_p1(dev, 0xE2, 0x00);
  200. _panel_transmit_p1(dev, 0xE3, 0x00);
  201. _panel_transmit_p1(dev, 0xE4, 0xE0);
  202. _panel_transmit_p1(dev, 0xE5, 0x06);
  203. _panel_transmit_p1(dev, 0xE6, 0x21);
  204. _panel_transmit_p1(dev, 0xE7, 0x00);
  205. _panel_transmit_p1(dev, 0xE8, 0x05);
  206. _panel_transmit_p1(dev, 0xE9, 0x82);
  207. _panel_transmit_p1(dev, 0xEA, 0xDF);
  208. _panel_transmit_p1(dev, 0xEB, 0x89);
  209. _panel_transmit_p1(dev, 0xEC, 0x20);
  210. _panel_transmit_p1(dev, 0xED, 0x14);
  211. _panel_transmit_p1(dev, 0xEE, 0xFF);
  212. _panel_transmit_p1(dev, 0xEF, 0x00);
  213. _panel_transmit_p1(dev, 0xF8, 0xFF);
  214. _panel_transmit_p1(dev, 0xF9, 0x00);
  215. _panel_transmit_p1(dev, 0xFA, 0x00);
  216. _panel_transmit_p1(dev, 0xFB, 0x30);
  217. _panel_transmit_p1(dev, 0xFC, 0x00);
  218. _panel_transmit_p1(dev, 0xFD, 0x00);
  219. _panel_transmit_p1(dev, 0xFE, 0x00);
  220. _panel_transmit_p1(dev, 0xFF, 0x00);
  221. _panel_transmit_p1(dev, 0x60, 0x42);
  222. _panel_transmit_p1(dev, 0x61, 0xE0);
  223. _panel_transmit_p1(dev, 0x62, 0x40);
  224. _panel_transmit_p1(dev, 0x63, 0x40);
  225. _panel_transmit_p1(dev, 0x64, 0x02);
  226. _panel_transmit_p1(dev, 0x65, 0x00);
  227. _panel_transmit_p1(dev, 0x66, 0x40);
  228. _panel_transmit_p1(dev, 0x67, 0x03);
  229. _panel_transmit_p1(dev, 0x68, 0x00);
  230. _panel_transmit_p1(dev, 0x69, 0x00);
  231. _panel_transmit_p1(dev, 0x6A, 0x00);
  232. _panel_transmit_p1(dev, 0x6B, 0x00);
  233. _panel_transmit_p1(dev, 0x70, 0x42);
  234. _panel_transmit_p1(dev, 0x71, 0xE0);
  235. _panel_transmit_p1(dev, 0x72, 0x40);
  236. _panel_transmit_p1(dev, 0x73, 0x40);
  237. _panel_transmit_p1(dev, 0x74, 0x02);
  238. _panel_transmit_p1(dev, 0x75, 0x00);
  239. _panel_transmit_p1(dev, 0x76, 0x40);
  240. _panel_transmit_p1(dev, 0x77, 0x03);
  241. _panel_transmit_p1(dev, 0x78, 0x00);
  242. _panel_transmit_p1(dev, 0x79, 0x00);
  243. _panel_transmit_p1(dev, 0x7A, 0x00);
  244. _panel_transmit_p1(dev, 0x7B, 0x00);
  245. _panel_transmit_p1(dev, 0x80, 0x48);
  246. _panel_transmit_p1(dev, 0x81, 0x00);
  247. _panel_transmit_p1(dev, 0x82, 0x05);
  248. _panel_transmit_p1(dev, 0x83, 0x02);
  249. _panel_transmit_p1(dev, 0x84, 0xDD);
  250. _panel_transmit_p1(dev, 0x85, 0x00);
  251. _panel_transmit_p1(dev, 0x86, 0x00);
  252. _panel_transmit_p1(dev, 0x87, 0x00);
  253. _panel_transmit_p1(dev, 0x88, 0x48);
  254. _panel_transmit_p1(dev, 0x89, 0x00);
  255. _panel_transmit_p1(dev, 0x8A, 0x07);
  256. _panel_transmit_p1(dev, 0x8B, 0x02);
  257. _panel_transmit_p1(dev, 0x8C, 0xDF);
  258. _panel_transmit_p1(dev, 0x8D, 0x00);
  259. _panel_transmit_p1(dev, 0x8E, 0x00);
  260. _panel_transmit_p1(dev, 0x8F, 0x00);
  261. _panel_transmit_p1(dev, 0x90, 0x48);
  262. _panel_transmit_p1(dev, 0x91, 0x00);
  263. _panel_transmit_p1(dev, 0x92, 0x09);
  264. _panel_transmit_p1(dev, 0x93, 0x02);
  265. _panel_transmit_p1(dev, 0x94, 0xE1);
  266. _panel_transmit_p1(dev, 0x95, 0x00);
  267. _panel_transmit_p1(dev, 0x96, 0x00);
  268. _panel_transmit_p1(dev, 0x97, 0x00);
  269. _panel_transmit_p1(dev, 0x98, 0x48);
  270. _panel_transmit_p1(dev, 0x99, 0x00);
  271. _panel_transmit_p1(dev, 0x9A, 0x0B);
  272. _panel_transmit_p1(dev, 0x9B, 0x02);
  273. _panel_transmit_p1(dev, 0x9C, 0xE3);
  274. _panel_transmit_p1(dev, 0x9D, 0x00);
  275. _panel_transmit_p1(dev, 0x9E, 0x00);
  276. _panel_transmit_p1(dev, 0x9F, 0x00);
  277. _panel_transmit_p1(dev, 0xA0, 0x48);
  278. _panel_transmit_p1(dev, 0xA1, 0x00);
  279. _panel_transmit_p1(dev, 0xA2, 0x04);
  280. _panel_transmit_p1(dev, 0xA3, 0x02);
  281. _panel_transmit_p1(dev, 0xA4, 0xDC);
  282. _panel_transmit_p1(dev, 0xA5, 0x00);
  283. _panel_transmit_p1(dev, 0xA6, 0x00);
  284. _panel_transmit_p1(dev, 0xA7, 0x00);
  285. _panel_transmit_p1(dev, 0xA8, 0x48);
  286. _panel_transmit_p1(dev, 0xA9, 0x00);
  287. _panel_transmit_p1(dev, 0xAA, 0x06);
  288. _panel_transmit_p1(dev, 0xAB, 0x02);
  289. _panel_transmit_p1(dev, 0xAC, 0xDE);
  290. _panel_transmit_p1(dev, 0xAD, 0x00);
  291. _panel_transmit_p1(dev, 0xAE, 0x00);
  292. _panel_transmit_p1(dev, 0xAF, 0x00);
  293. _panel_transmit_p1(dev, 0xB0, 0x48);
  294. _panel_transmit_p1(dev, 0xB1, 0x00);
  295. _panel_transmit_p1(dev, 0xB2, 0x08);
  296. _panel_transmit_p1(dev, 0xB3, 0x02);
  297. _panel_transmit_p1(dev, 0xB4, 0xE0);
  298. _panel_transmit_p1(dev, 0xB5, 0x00);
  299. _panel_transmit_p1(dev, 0xB6, 0x00);
  300. _panel_transmit_p1(dev, 0xB7, 0x00);
  301. _panel_transmit_p1(dev, 0xB8, 0x48);
  302. _panel_transmit_p1(dev, 0xB9, 0x00);
  303. _panel_transmit_p1(dev, 0xBA, 0x0A);
  304. _panel_transmit_p1(dev, 0xBB, 0x02);
  305. _panel_transmit_p1(dev, 0xBC, 0xE2);
  306. _panel_transmit_p1(dev, 0xBD, 0x00);
  307. _panel_transmit_p1(dev, 0xBE, 0x00);
  308. _panel_transmit_p1(dev, 0xBF, 0x00);
  309. _panel_transmit_p1(dev, 0xC0, 0x12);
  310. _panel_transmit_p1(dev, 0xC1, 0xAA);
  311. _panel_transmit_p1(dev, 0xC2, 0x65);
  312. _panel_transmit_p1(dev, 0xC3, 0x74);
  313. _panel_transmit_p1(dev, 0xC4, 0x47);
  314. _panel_transmit_p1(dev, 0xC5, 0x56);
  315. _panel_transmit_p1(dev, 0xC6, 0x00);
  316. _panel_transmit_p1(dev, 0xC7, 0x88);
  317. _panel_transmit_p1(dev, 0xC8, 0x99);
  318. _panel_transmit_p1(dev, 0xC9, 0x33);
  319. _panel_transmit_p1(dev, 0xD0, 0x21);
  320. _panel_transmit_p1(dev, 0xD1, 0xAA);
  321. _panel_transmit_p1(dev, 0xD2, 0x65);
  322. _panel_transmit_p1(dev, 0xD3, 0x74);
  323. _panel_transmit_p1(dev, 0xD4, 0x47);
  324. _panel_transmit_p1(dev, 0xD5, 0x56);
  325. _panel_transmit_p1(dev, 0xD6, 0x00);
  326. _panel_transmit_p1(dev, 0xD7, 0x88);
  327. _panel_transmit_p1(dev, 0xD8, 0x99);
  328. _panel_transmit_p1(dev, 0xD9, 0x33);
  329. _panel_transmit_p1(dev, 0xF3, 0x01);
  330. _panel_transmit_p1(dev, 0xF0, 0x00);
  331. _panel_transmit_p1(dev, 0xF0, 0x01);
  332. _panel_transmit_p1(dev, 0xF1, 0x01);
  333. _panel_transmit_p1(dev, 0xA0, 0x0B);
  334. _panel_transmit_p1(dev, 0xA3, 0x2A);
  335. _panel_transmit_p1(dev, 0xA5, 0xC3);
  336. k_msleep(1);
  337. _panel_transmit_p1(dev, 0xA3, 0x2B);
  338. _panel_transmit_p1(dev, 0xA5, 0xC3);
  339. k_msleep(1);
  340. _panel_transmit_p1(dev, 0xA3, 0x2C);
  341. _panel_transmit_p1(dev, 0xA5, 0xC3);
  342. k_msleep(1);
  343. _panel_transmit_p1(dev, 0xA3, 0x2D);
  344. _panel_transmit_p1(dev, 0xA5, 0xC3);
  345. k_msleep(1);
  346. _panel_transmit_p1(dev, 0xA3, 0x2E);
  347. _panel_transmit_p1(dev, 0xA5, 0xC3);
  348. k_msleep(1);
  349. _panel_transmit_p1(dev, 0xA3, 0x2F);
  350. _panel_transmit_p1(dev, 0xA5, 0xC3);
  351. k_msleep(1);
  352. _panel_transmit_p1(dev, 0xA3, 0x30);
  353. _panel_transmit_p1(dev, 0xA5, 0xC3);
  354. k_msleep(1);
  355. _panel_transmit_p1(dev, 0xA3, 0x31);
  356. _panel_transmit_p1(dev, 0xA5, 0xC3);
  357. k_msleep(1);
  358. _panel_transmit_p1(dev, 0xA3, 0x32);
  359. _panel_transmit_p1(dev, 0xA5, 0xC3);
  360. k_msleep(1);
  361. _panel_transmit_p1(dev, 0xA3, 0x33);
  362. _panel_transmit_p1(dev, 0xA5, 0xC3);
  363. k_msleep(1);
  364. _panel_transmit_p1(dev, 0xA0, 0x09);
  365. _panel_transmit_p1(dev, 0xF1, 0x10);
  366. _panel_transmit_p1(dev, 0xF0, 0x00);
  367. const uint8_t data_0x2a[] = {
  368. 0x00,
  369. 0x00,
  370. 0x01,
  371. 0x67,
  372. };
  373. _panel_transmit(dev, 0x2a, data_0x2a, sizeof(data_0x2a));
  374. const uint8_t data_0x2b[] = {
  375. 0x01,
  376. 0x68,
  377. 0x01,
  378. 0x68,
  379. };
  380. _panel_transmit(dev, 0x2b, data_0x2b, sizeof(data_0x2b));
  381. _panel_transmit_p1(dev, 0x4D, 0x00);
  382. _panel_transmit_p1(dev, 0x4E, 0x00);
  383. _panel_transmit_p1(dev, 0x4F, 0x00);
  384. _panel_transmit_p1(dev, 0x4C, 0x01);
  385. k_msleep(10);
  386. _panel_transmit_p1(dev, 0x4C, 0x00);
  387. _panel_transmit(dev, 0x2a, data_0x2a, sizeof(data_0x2a));
  388. _panel_transmit(dev, 0x2b, data_0x2a, sizeof(data_0x2a));
  389. _panel_transmit_cmd(dev, 0x21);
  390. /* TE */
  391. _panel_transmit_p2(dev, DDIC_CMD_STESL, CONFIG_PANEL_TE_SCANLINE >> 8,
  392. CONFIG_PANEL_TE_SCANLINE & 0xff);
  393. _panel_transmit_p1(dev, DDIC_CMD_TEON, 0x00);
  394. _panel_transmit_p1(dev, 0x53, 0x20);
  395. _panel_transmit_cmd(dev, 0x11); /* Sleep Out */
  396. k_msleep(120);
  397. _panel_transmit_p1(dev, 0x3a, 0x55);
  398. _panel_transmit_cmd(dev, 0x29); /* Display On */
  399. k_msleep(50);
  400. //_panel_transmit_cmd(dev, 0x1c);
  401. //k_msleep(120);
  402. #else //伊欧 LCM 2025.5.12
  403. _panel_transmit_p1(dev, 0xf0, 0x28);
  404. _panel_transmit_p1(dev, 0xF2, 0x28);
  405. _panel_transmit_p1(dev, 0x73, 0xF0);
  406. _panel_transmit_p1(dev, 0x7C, 0xD1);
  407. _panel_transmit_p1(dev, 0x83, 0xE0);
  408. _panel_transmit_p1(dev, 0x84, 0x61);
  409. _panel_transmit_p1(dev, 0xF2, 0x82);
  410. _panel_transmit_p1(dev, 0xF0, 0x00);
  411. _panel_transmit_p1(dev, 0xF0, 0x01);
  412. _panel_transmit_p1(dev, 0xF1, 0x01);
  413. _panel_transmit_p1(dev, 0xB0, 0x65);
  414. _panel_transmit_p1(dev, 0xB1, 0x3E);
  415. _panel_transmit_p1(dev, 0xB2, 0x33);
  416. _panel_transmit_p1(dev, 0xB3, 0x01);
  417. _panel_transmit_p1(dev, 0xB4, 0x69);
  418. _panel_transmit_p1(dev, 0xB5, 0x45);
  419. _panel_transmit_p1(dev, 0xB6, 0x8B);
  420. _panel_transmit_p1(dev, 0xB7, 0x41);
  421. _panel_transmit_p1(dev, 0xB8, 0x86);
  422. _panel_transmit_p1(dev, 0xB9, 0x15);
  423. _panel_transmit_p1(dev, 0xBA, 0x00);
  424. _panel_transmit_p1(dev, 0xBB, 0x08);
  425. _panel_transmit_p1(dev, 0xBC, 0x08);
  426. _panel_transmit_p1(dev, 0xBD, 0x00);
  427. _panel_transmit_p1(dev, 0xBE, 0x00);
  428. _panel_transmit_p1(dev, 0xBF, 0x07);
  429. _panel_transmit_p1(dev, 0xC0, 0x80);
  430. _panel_transmit_p1(dev, 0xC1, 0x10);
  431. _panel_transmit_p1(dev, 0xC2, 0x37);
  432. _panel_transmit_p1(dev, 0xC3, 0x80);
  433. _panel_transmit_p1(dev, 0xC4, 0x10);
  434. _panel_transmit_p1(dev, 0xC5, 0x37);
  435. _panel_transmit_p1(dev, 0xC6, 0xA9);
  436. _panel_transmit_p1(dev, 0xC7, 0x41);
  437. _panel_transmit_p1(dev, 0xC8, 0x01);
  438. _panel_transmit_p1(dev, 0xC9, 0xA9);
  439. _panel_transmit_p1(dev, 0xCA, 0x41);
  440. _panel_transmit_p1(dev, 0xCB, 0x01);
  441. _panel_transmit_p1(dev, 0xCC, 0x7F);
  442. _panel_transmit_p1(dev, 0xCD, 0x7F);
  443. _panel_transmit_p1(dev, 0xCE, 0xFF);
  444. _panel_transmit_p1(dev, 0xD0, 0x91);
  445. _panel_transmit_p1(dev, 0xD1, 0x68);
  446. _panel_transmit_p1(dev, 0xD2, 0x68);
  447. const uint8_t data_0xf5[] = {
  448. 0x00,
  449. 0xA5,
  450. };
  451. _panel_transmit(dev, 0xF5, data_0xf5, sizeof(data_0xf5));
  452. _panel_transmit_p1(dev, 0xF1, 0x10);
  453. _panel_transmit_p1(dev, 0xF0, 0x00);
  454. _panel_transmit_p1(dev, 0xF0, 0x02);
  455. const uint8_t data_0xe0[] = {
  456. 0xF0, 0x09, 0x0F, 0x09, 0x0A, 0x16, 0x35, 0x33, 0x4A, 0x18, 0x15, 0x15, 0x2E, 0x34,
  457. };
  458. _panel_transmit(dev, 0xE0, data_0xe0, sizeof(data_0xe0));
  459. const uint8_t data_0xe1[] = {
  460. 0xF0, 0x09, 0x0F, 0x09, 0x09, 0x16, 0x34, 0x33, 0x4A, 0x18, 0x14, 0x15, 0x2D, 0x33,
  461. };
  462. _panel_transmit(dev, 0xE1, data_0xe1, sizeof(data_0xe1));
  463. _panel_transmit_p1(dev, 0xF0, 0x10);
  464. _panel_transmit_p1(dev, 0xF3, 0x10);
  465. _panel_transmit_p1(dev, 0xE0, 0x08);
  466. _panel_transmit_p1(dev, 0xE1, 0x00);
  467. _panel_transmit_p1(dev, 0xE2, 0x00);
  468. _panel_transmit_p1(dev, 0xE3, 0x00);
  469. _panel_transmit_p1(dev, 0xE4, 0xE0);
  470. _panel_transmit_p1(dev, 0xE5, 0x06);
  471. _panel_transmit_p1(dev, 0xE6, 0x21);
  472. _panel_transmit_p1(dev, 0xE7, 0x03);
  473. _panel_transmit_p1(dev, 0xE8, 0x05);
  474. _panel_transmit_p1(dev, 0xE9, 0x02);
  475. _panel_transmit_p1(dev, 0xEA, 0xE9);
  476. _panel_transmit_p1(dev, 0xEB, 0x00);
  477. _panel_transmit_p1(dev, 0xEC, 0x00);
  478. _panel_transmit_p1(dev, 0xED, 0x14);
  479. _panel_transmit_p1(dev, 0xEE, 0xFF);
  480. _panel_transmit_p1(dev, 0xEF, 0x00);
  481. _panel_transmit_p1(dev, 0xF8, 0xFF);
  482. _panel_transmit_p1(dev, 0xF9, 0x00);
  483. _panel_transmit_p1(dev, 0xFA, 0x00);
  484. _panel_transmit_p1(dev, 0xFB, 0x30);
  485. _panel_transmit_p1(dev, 0xFC, 0x00);
  486. _panel_transmit_p1(dev, 0xFD, 0x00);
  487. _panel_transmit_p1(dev, 0xFE, 0x00);
  488. _panel_transmit_p1(dev, 0xFF, 0x00);
  489. _panel_transmit_p1(dev, 0x60, 0x40);
  490. _panel_transmit_p1(dev, 0x61, 0x05);
  491. _panel_transmit_p1(dev, 0x62, 0x00);
  492. _panel_transmit_p1(dev, 0x63, 0x42);
  493. _panel_transmit_p1(dev, 0x64, 0xDA);
  494. _panel_transmit_p1(dev, 0x65, 0x00);
  495. _panel_transmit_p1(dev, 0x66, 0x00);
  496. _panel_transmit_p1(dev, 0x67, 0x00);
  497. _panel_transmit_p1(dev, 0x68, 0x00);
  498. _panel_transmit_p1(dev, 0x69, 0x00);
  499. _panel_transmit_p1(dev, 0x6A, 0x00);
  500. _panel_transmit_p1(dev, 0x6B, 0x00);
  501. _panel_transmit_p1(dev, 0x70, 0x40);
  502. _panel_transmit_p1(dev, 0x71, 0x04);
  503. _panel_transmit_p1(dev, 0x72, 0x00);
  504. _panel_transmit_p1(dev, 0x73, 0x42);
  505. _panel_transmit_p1(dev, 0x74, 0xD9);
  506. _panel_transmit_p1(dev, 0x75, 0x00);
  507. _panel_transmit_p1(dev, 0x76, 0x00);
  508. _panel_transmit_p1(dev, 0x77, 0x00);
  509. _panel_transmit_p1(dev, 0x78, 0x00);
  510. _panel_transmit_p1(dev, 0x79, 0x00);
  511. _panel_transmit_p1(dev, 0x7A, 0x00);
  512. _panel_transmit_p1(dev, 0x7B, 0x00);
  513. _panel_transmit_p1(dev, 0x80, 0x48);
  514. _panel_transmit_p1(dev, 0x81, 0x00);
  515. _panel_transmit_p1(dev, 0x82, 0x07);
  516. _panel_transmit_p1(dev, 0x83, 0x02);
  517. _panel_transmit_p1(dev, 0x84, 0xD7);
  518. _panel_transmit_p1(dev, 0x85, 0x04);
  519. _panel_transmit_p1(dev, 0x86, 0x00);
  520. _panel_transmit_p1(dev, 0x87, 0x00);
  521. _panel_transmit_p1(dev, 0x88, 0x48);
  522. _panel_transmit_p1(dev, 0x89, 0x00);
  523. _panel_transmit_p1(dev, 0x8A, 0x09);
  524. _panel_transmit_p1(dev, 0x8B, 0x02);
  525. _panel_transmit_p1(dev, 0x8C, 0xD9);
  526. _panel_transmit_p1(dev, 0x8D, 0x04);
  527. _panel_transmit_p1(dev, 0x8E, 0x00);
  528. _panel_transmit_p1(dev, 0x8F, 0x00);
  529. _panel_transmit_p1(dev, 0x90, 0x48);
  530. _panel_transmit_p1(dev, 0x91, 0x00);
  531. _panel_transmit_p1(dev, 0x92, 0x0B);
  532. _panel_transmit_p1(dev, 0x93, 0x02);
  533. _panel_transmit_p1(dev, 0x94, 0xDB);
  534. _panel_transmit_p1(dev, 0x95, 0x04);
  535. _panel_transmit_p1(dev, 0x96, 0x00);
  536. _panel_transmit_p1(dev, 0x97, 0x00);
  537. _panel_transmit_p1(dev, 0x98, 0x48);
  538. _panel_transmit_p1(dev, 0x99, 0x00);
  539. _panel_transmit_p1(dev, 0x9A, 0x0D);
  540. _panel_transmit_p1(dev, 0x9B, 0x02);
  541. _panel_transmit_p1(dev, 0x9C, 0xDD);
  542. _panel_transmit_p1(dev, 0x9D, 0x04);
  543. _panel_transmit_p1(dev, 0x9E, 0x00);
  544. _panel_transmit_p1(dev, 0x9F, 0x00);
  545. _panel_transmit_p1(dev, 0xA0, 0x48);
  546. _panel_transmit_p1(dev, 0xA1, 0x00);
  547. _panel_transmit_p1(dev, 0xA2, 0x06);
  548. _panel_transmit_p1(dev, 0xA3, 0x02);
  549. _panel_transmit_p1(dev, 0xA4, 0xD6);
  550. _panel_transmit_p1(dev, 0xA5, 0x04);
  551. _panel_transmit_p1(dev, 0xA6, 0x00);
  552. _panel_transmit_p1(dev, 0xA7, 0x00);
  553. _panel_transmit_p1(dev, 0xA8, 0x48);
  554. _panel_transmit_p1(dev, 0xA9, 0x00);
  555. _panel_transmit_p1(dev, 0xAA, 0x08);
  556. _panel_transmit_p1(dev, 0xAB, 0x02);
  557. _panel_transmit_p1(dev, 0xAC, 0xD8);
  558. _panel_transmit_p1(dev, 0xAD, 0x04);
  559. _panel_transmit_p1(dev, 0xAE, 0x00);
  560. _panel_transmit_p1(dev, 0xAF, 0x00);
  561. _panel_transmit_p1(dev, 0xB0, 0x48);
  562. _panel_transmit_p1(dev, 0xB1, 0x00);
  563. _panel_transmit_p1(dev, 0xB2, 0x0A);
  564. _panel_transmit_p1(dev, 0xB3, 0x02);
  565. _panel_transmit_p1(dev, 0xB4, 0xDA);
  566. _panel_transmit_p1(dev, 0xB5, 0x04);
  567. _panel_transmit_p1(dev, 0xB6, 0x00);
  568. _panel_transmit_p1(dev, 0xB7, 0x00);
  569. _panel_transmit_p1(dev, 0xB8, 0x48);
  570. _panel_transmit_p1(dev, 0xB9, 0x00);
  571. _panel_transmit_p1(dev, 0xBA, 0x0C);
  572. _panel_transmit_p1(dev, 0xBB, 0x02);
  573. _panel_transmit_p1(dev, 0xBC, 0xDC);
  574. _panel_transmit_p1(dev, 0xBD, 0x04);
  575. _panel_transmit_p1(dev, 0xBE, 0x00);
  576. _panel_transmit_p1(dev, 0xBF, 0x00);
  577. _panel_transmit_p1(dev, 0xC0, 0x10);
  578. _panel_transmit_p1(dev, 0xC1, 0x47);
  579. _panel_transmit_p1(dev, 0xC2, 0x56);
  580. _panel_transmit_p1(dev, 0xC3, 0x65);
  581. _panel_transmit_p1(dev, 0xC4, 0x74);
  582. _panel_transmit_p1(dev, 0xC5, 0x88);
  583. _panel_transmit_p1(dev, 0xC6, 0x99);
  584. _panel_transmit_p1(dev, 0xC7, 0x01);
  585. _panel_transmit_p1(dev, 0xC8, 0xBB);
  586. _panel_transmit_p1(dev, 0xC9, 0xAA);
  587. _panel_transmit_p1(dev, 0xD0, 0x10);
  588. _panel_transmit_p1(dev, 0xD1, 0x47);
  589. _panel_transmit_p1(dev, 0xD2, 0x56);
  590. _panel_transmit_p1(dev, 0xD3, 0x65);
  591. _panel_transmit_p1(dev, 0xD4, 0x74);
  592. _panel_transmit_p1(dev, 0xD5, 0x88);
  593. _panel_transmit_p1(dev, 0xD6, 0x99);
  594. _panel_transmit_p1(dev, 0xD7, 0x01);
  595. _panel_transmit_p1(dev, 0xD8, 0xBB);
  596. _panel_transmit_p1(dev, 0xD9, 0xAA);
  597. _panel_transmit_p1(dev, 0xF3, 0x01);
  598. _panel_transmit_p1(dev, 0xF0, 0x00);
  599. _panel_transmit_p1(dev, 0x3A, 0x05);
  600. _panel_transmit_p1(dev, 0x36, 0x00);
  601. _panel_transmit_p1(dev, 0x35, 0x00); //TE
  602. _panel_transmit_cmd(dev, 0x21);
  603. _panel_transmit_cmd(dev, 0x11); /* Sleep Out */
  604. k_msleep(120);
  605. _panel_transmit_cmd(dev, 0x29); /* Display On */
  606. //k_msleep(120);
  607. //_panel_transmit_cmd(dev, 0x1c);
  608. //k_msleep(120);
  609. #endif
  610. // _panel_init_te(dev);
  611. printk("st77916 panel_init exit\r\n ");
  612. return 0;
  613. }
  614. static const struct lcd_panel_ops lcd_panel_ops = {
  615. .init = _panel_init,
  616. .blanking_on = _panel_blanking_on,
  617. .blanking_off = _panel_blanking_off,
  618. .lowpower_enter = _panel_lowpower_enter,
  619. .lowpower_exit = _panel_lowpower_exit,
  620. .set_brightness = _panel_set_brightness,
  621. .write_prepare = _panel_set_mem_area,
  622. };
  623. const struct lcd_panel_config lcd_panel_st77916_config = {
  624. .videoport = PANEL_VIDEO_PORT_INITIALIZER,
  625. .videomode = PANEL_VIDEO_MODE_INITIALIZER,
  626. .ops = &lcd_panel_ops,
  627. .cmd_ramwr = (0x32 << 24 | DDIC_CMD_RAMWR << 8),
  628. .cmd_ramwc = (0x32 << 24 | DDIC_CMD_RAMWRC << 8),
  629. .tw_reset = 10,
  630. .ts_reset = 120,
  631. };