dsi_ctrl_hw_1_4.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2015-2019, The Linux Foundation. All rights reserved.
  4. */
  5. #define pr_fmt(fmt) "dsi-hw:" fmt
  6. #include <linux/delay.h>
  7. #include <linux/iopoll.h>
  8. #include "dsi_ctrl_hw.h"
  9. #include "dsi_ctrl_reg.h"
  10. #include "dsi_hw.h"
  11. #define MMSS_MISC_CLAMP_REG_OFF 0x0014
  12. /**
  13. * dsi_ctrl_hw_14_setup_lane_map() - setup mapping between
  14. * logical and physical lanes
  15. * @ctrl: Pointer to the controller host hardware.
  16. * @lane_map: Structure defining the mapping between DSI logical
  17. * lanes and physical lanes.
  18. */
  19. void dsi_ctrl_hw_14_setup_lane_map(struct dsi_ctrl_hw *ctrl,
  20. struct dsi_lane_map *lane_map)
  21. {
  22. DSI_W32(ctrl, DSI_LANE_SWAP_CTRL, lane_map->lane_map_v1);
  23. pr_debug("[DSI_%d] Lane swap setup complete\n", ctrl->index);
  24. }
  25. /**
  26. * dsi_ctrl_hw_14_wait_for_lane_idle()
  27. * This function waits for all the active DSI lanes to be idle by polling all
  28. * the FIFO_EMPTY bits and polling he lane status to ensure that all the lanes
  29. * are in stop state. This function assumes that the bus clocks required to
  30. * access the registers are already turned on.
  31. *
  32. * @ctrl: Pointer to the controller host hardware.
  33. * @lanes: ORed list of lanes (enum dsi_data_lanes) which need
  34. * to be stopped.
  35. *
  36. * return: Error code.
  37. */
  38. int dsi_ctrl_hw_14_wait_for_lane_idle(struct dsi_ctrl_hw *ctrl, u32 lanes)
  39. {
  40. int rc = 0, val = 0;
  41. u32 stop_state_mask = 0, fifo_empty_mask = 0;
  42. u32 const sleep_us = 10;
  43. u32 const timeout_us = 100;
  44. if (lanes & DSI_DATA_LANE_0) {
  45. stop_state_mask |= BIT(0);
  46. fifo_empty_mask |= (BIT(12) | BIT(16));
  47. }
  48. if (lanes & DSI_DATA_LANE_1) {
  49. stop_state_mask |= BIT(1);
  50. fifo_empty_mask |= BIT(20);
  51. }
  52. if (lanes & DSI_DATA_LANE_2) {
  53. stop_state_mask |= BIT(2);
  54. fifo_empty_mask |= BIT(24);
  55. }
  56. if (lanes & DSI_DATA_LANE_3) {
  57. stop_state_mask |= BIT(3);
  58. fifo_empty_mask |= BIT(28);
  59. }
  60. pr_debug("%s: polling for fifo empty, mask=0x%08x\n", __func__,
  61. fifo_empty_mask);
  62. rc = readl_poll_timeout(ctrl->base + DSI_FIFO_STATUS, val,
  63. (val & fifo_empty_mask), sleep_us, timeout_us);
  64. if (rc) {
  65. pr_err("%s: fifo not empty, FIFO_STATUS=0x%08x\n",
  66. __func__, val);
  67. goto error;
  68. }
  69. pr_debug("%s: polling for lanes to be in stop state, mask=0x%08x\n",
  70. __func__, stop_state_mask);
  71. rc = readl_poll_timeout(ctrl->base + DSI_LANE_STATUS, val,
  72. (val & stop_state_mask), sleep_us, timeout_us);
  73. if (rc) {
  74. pr_err("%s: lanes not in stop state, LANE_STATUS=0x%08x\n",
  75. __func__, val);
  76. goto error;
  77. }
  78. error:
  79. return rc;
  80. }
  81. /**
  82. * ulps_request() - request ulps entry for specified lanes
  83. * @ctrl: Pointer to the controller host hardware.
  84. * @lanes: ORed list of lanes (enum dsi_data_lanes) which need
  85. * to enter ULPS.
  86. *
  87. * Caller should check if lanes are in ULPS mode by calling
  88. * get_lanes_in_ulps() operation.
  89. */
  90. void dsi_ctrl_hw_cmn_ulps_request(struct dsi_ctrl_hw *ctrl, u32 lanes)
  91. {
  92. u32 reg = 0;
  93. reg = DSI_R32(ctrl, DSI_LANE_CTRL);
  94. if (lanes & DSI_CLOCK_LANE)
  95. reg |= BIT(4);
  96. if (lanes & DSI_DATA_LANE_0)
  97. reg |= BIT(0);
  98. if (lanes & DSI_DATA_LANE_1)
  99. reg |= BIT(1);
  100. if (lanes & DSI_DATA_LANE_2)
  101. reg |= BIT(2);
  102. if (lanes & DSI_DATA_LANE_3)
  103. reg |= BIT(3);
  104. /*
  105. * ULPS entry request. Wait for short time to make sure
  106. * that the lanes enter ULPS. Recommended as per HPG.
  107. */
  108. DSI_W32(ctrl, DSI_LANE_CTRL, reg);
  109. usleep_range(100, 110);
  110. pr_debug("[DSI_%d] ULPS requested for lanes 0x%x\n", ctrl->index,
  111. lanes);
  112. }
  113. /**
  114. * ulps_exit() - exit ULPS on specified lanes
  115. * @ctrl: Pointer to the controller host hardware.
  116. * @lanes: ORed list of lanes (enum dsi_data_lanes) which need
  117. * to exit ULPS.
  118. *
  119. * Caller should check if lanes are in active mode by calling
  120. * get_lanes_in_ulps() operation.
  121. */
  122. void dsi_ctrl_hw_cmn_ulps_exit(struct dsi_ctrl_hw *ctrl, u32 lanes)
  123. {
  124. u32 reg = 0;
  125. u32 prev_reg = 0;
  126. prev_reg = DSI_R32(ctrl, DSI_LANE_CTRL);
  127. prev_reg &= BIT(24);
  128. if (lanes & DSI_CLOCK_LANE)
  129. reg |= BIT(12);
  130. if (lanes & DSI_DATA_LANE_0)
  131. reg |= BIT(8);
  132. if (lanes & DSI_DATA_LANE_1)
  133. reg |= BIT(9);
  134. if (lanes & DSI_DATA_LANE_2)
  135. reg |= BIT(10);
  136. if (lanes & DSI_DATA_LANE_3)
  137. reg |= BIT(11);
  138. /*
  139. * ULPS Exit Request
  140. * Hardware requirement is to wait for at least 1ms
  141. */
  142. DSI_W32(ctrl, DSI_LANE_CTRL, reg | prev_reg);
  143. usleep_range(1000, 1010);
  144. /*
  145. * Sometimes when exiting ULPS, it is possible that some DSI
  146. * lanes are not in the stop state which could lead to DSI
  147. * commands not going through. To avoid this, force the lanes
  148. * to be in stop state.
  149. */
  150. DSI_W32(ctrl, DSI_LANE_CTRL, (reg << 8) | prev_reg);
  151. wmb(); /* ensure lanes are put to stop state */
  152. DSI_W32(ctrl, DSI_LANE_CTRL, 0x0 | prev_reg);
  153. wmb(); /* ensure lanes are put to stop state */
  154. pr_debug("[DSI_%d] ULPS exit request for lanes=0x%x\n",
  155. ctrl->index, lanes);
  156. }
  157. /**
  158. * get_lanes_in_ulps() - returns the list of lanes in ULPS mode
  159. * @ctrl: Pointer to the controller host hardware.
  160. *
  161. * Returns an ORed list of lanes (enum dsi_data_lanes) that are in ULPS
  162. * state. If 0 is returned, all the lanes are active.
  163. *
  164. * Return: List of lanes in ULPS state.
  165. */
  166. u32 dsi_ctrl_hw_cmn_get_lanes_in_ulps(struct dsi_ctrl_hw *ctrl)
  167. {
  168. u32 reg = 0;
  169. u32 lanes = 0;
  170. reg = DSI_R32(ctrl, DSI_LANE_STATUS);
  171. if (!(reg & BIT(8)))
  172. lanes |= DSI_DATA_LANE_0;
  173. if (!(reg & BIT(9)))
  174. lanes |= DSI_DATA_LANE_1;
  175. if (!(reg & BIT(10)))
  176. lanes |= DSI_DATA_LANE_2;
  177. if (!(reg & BIT(11)))
  178. lanes |= DSI_DATA_LANE_3;
  179. if (!(reg & BIT(12)))
  180. lanes |= DSI_CLOCK_LANE;
  181. pr_debug("[DSI_%d] lanes in ulps = 0x%x\n", ctrl->index, lanes);
  182. return lanes;
  183. }
  184. /**
  185. * clamp_enable() - enable DSI clamps to keep PHY driving a stable link
  186. * @ctrl: Pointer to the controller host hardware.
  187. * @lanes: ORed list of lanes which need to be clamped.
  188. * @enable_ulps: Boolean to specify if ULPS is enabled in DSI controller
  189. */
  190. void dsi_ctrl_hw_14_clamp_enable(struct dsi_ctrl_hw *ctrl,
  191. u32 lanes,
  192. bool enable_ulps)
  193. {
  194. u32 clamp_reg = 0;
  195. u32 bit_shift = 0;
  196. u32 reg = 0;
  197. if (ctrl->index == 1)
  198. bit_shift = 16;
  199. if (lanes & DSI_CLOCK_LANE) {
  200. clamp_reg |= BIT(9);
  201. if (enable_ulps)
  202. clamp_reg |= BIT(8);
  203. }
  204. if (lanes & DSI_DATA_LANE_0) {
  205. clamp_reg |= BIT(7);
  206. if (enable_ulps)
  207. clamp_reg |= BIT(6);
  208. }
  209. if (lanes & DSI_DATA_LANE_1) {
  210. clamp_reg |= BIT(5);
  211. if (enable_ulps)
  212. clamp_reg |= BIT(4);
  213. }
  214. if (lanes & DSI_DATA_LANE_2) {
  215. clamp_reg |= BIT(3);
  216. if (enable_ulps)
  217. clamp_reg |= BIT(2);
  218. }
  219. if (lanes & DSI_DATA_LANE_3) {
  220. clamp_reg |= BIT(1);
  221. if (enable_ulps)
  222. clamp_reg |= BIT(0);
  223. }
  224. reg = DSI_MMSS_MISC_R32(ctrl, MMSS_MISC_CLAMP_REG_OFF);
  225. reg |= (clamp_reg << bit_shift);
  226. DSI_MMSS_MISC_W32(ctrl, MMSS_MISC_CLAMP_REG_OFF, reg);
  227. reg = DSI_MMSS_MISC_R32(ctrl, MMSS_MISC_CLAMP_REG_OFF);
  228. reg |= (BIT(15) << bit_shift); /* Enable clamp */
  229. DSI_MMSS_MISC_W32(ctrl, MMSS_MISC_CLAMP_REG_OFF, reg);
  230. pr_debug("[DSI_%d] Clamps enabled for lanes=0x%x\n", ctrl->index,
  231. lanes);
  232. }
  233. /**
  234. * clamp_disable() - disable DSI clamps
  235. * @ctrl: Pointer to the controller host hardware.
  236. * @lanes: ORed list of lanes which need to have clamps released.
  237. * @disable_ulps: Boolean to specify if ULPS is enabled in DSI controller
  238. */
  239. void dsi_ctrl_hw_14_clamp_disable(struct dsi_ctrl_hw *ctrl,
  240. u32 lanes,
  241. bool disable_ulps)
  242. {
  243. u32 clamp_reg = 0;
  244. u32 bit_shift = 0;
  245. u32 reg = 0;
  246. if (ctrl->index == 1)
  247. bit_shift = 16;
  248. if (lanes & DSI_CLOCK_LANE) {
  249. clamp_reg |= BIT(9);
  250. if (disable_ulps)
  251. clamp_reg |= BIT(8);
  252. }
  253. if (lanes & DSI_DATA_LANE_0) {
  254. clamp_reg |= BIT(7);
  255. if (disable_ulps)
  256. clamp_reg |= BIT(6);
  257. }
  258. if (lanes & DSI_DATA_LANE_1) {
  259. clamp_reg |= BIT(5);
  260. if (disable_ulps)
  261. clamp_reg |= BIT(4);
  262. }
  263. if (lanes & DSI_DATA_LANE_2) {
  264. clamp_reg |= BIT(3);
  265. if (disable_ulps)
  266. clamp_reg |= BIT(2);
  267. }
  268. if (lanes & DSI_DATA_LANE_3) {
  269. clamp_reg |= BIT(1);
  270. if (disable_ulps)
  271. clamp_reg |= BIT(0);
  272. }
  273. clamp_reg |= BIT(15); /* Enable clamp */
  274. clamp_reg <<= bit_shift;
  275. reg = DSI_MMSS_MISC_R32(ctrl, MMSS_MISC_CLAMP_REG_OFF);
  276. reg &= ~(clamp_reg);
  277. DSI_MMSS_MISC_W32(ctrl, MMSS_MISC_CLAMP_REG_OFF, reg);
  278. pr_debug("[DSI_%d] Disable clamps for lanes=%d\n", ctrl->index, lanes);
  279. }
  280. #define DUMP_REG_VALUE(off) "\t%-30s: 0x%08x\n", #off, DSI_R32(ctrl, off)
  281. ssize_t dsi_ctrl_hw_14_reg_dump_to_buffer(struct dsi_ctrl_hw *ctrl,
  282. char *buf,
  283. u32 size)
  284. {
  285. u32 len = 0;
  286. len += snprintf((buf + len), (size - len), "CONFIGURATION REGS:\n");
  287. len += snprintf((buf + len), (size - len),
  288. DUMP_REG_VALUE(DSI_HW_VERSION));
  289. len += snprintf((buf + len), (size - len),
  290. DUMP_REG_VALUE(DSI_CTRL));
  291. len += snprintf((buf + len), (size - len),
  292. DUMP_REG_VALUE(DSI_STATUS));
  293. len += snprintf((buf + len), (size - len),
  294. DUMP_REG_VALUE(DSI_FIFO_STATUS));
  295. len += snprintf((buf + len), (size - len),
  296. DUMP_REG_VALUE(DSI_VIDEO_MODE_CTRL));
  297. len += snprintf((buf + len), (size - len),
  298. DUMP_REG_VALUE(DSI_VIDEO_MODE_SYNC_DATATYPE));
  299. len += snprintf((buf + len), (size - len),
  300. DUMP_REG_VALUE(DSI_VIDEO_MODE_PIXEL_DATATYPE));
  301. len += snprintf((buf + len), (size - len),
  302. DUMP_REG_VALUE(DSI_VIDEO_MODE_BLANKING_DATATYPE));
  303. len += snprintf((buf + len), (size - len),
  304. DUMP_REG_VALUE(DSI_VIDEO_MODE_DATA_CTRL));
  305. len += snprintf((buf + len), (size - len),
  306. DUMP_REG_VALUE(DSI_VIDEO_MODE_ACTIVE_H));
  307. len += snprintf((buf + len), (size - len),
  308. DUMP_REG_VALUE(DSI_VIDEO_MODE_ACTIVE_V));
  309. len += snprintf((buf + len), (size - len),
  310. DUMP_REG_VALUE(DSI_VIDEO_MODE_TOTAL));
  311. len += snprintf((buf + len), (size - len),
  312. DUMP_REG_VALUE(DSI_VIDEO_MODE_HSYNC));
  313. len += snprintf((buf + len), (size - len),
  314. DUMP_REG_VALUE(DSI_VIDEO_MODE_VSYNC));
  315. len += snprintf((buf + len), (size - len),
  316. DUMP_REG_VALUE(DSI_VIDEO_MODE_VSYNC_VPOS));
  317. len += snprintf((buf + len), (size - len),
  318. DUMP_REG_VALUE(DSI_COMMAND_MODE_DMA_CTRL));
  319. len += snprintf((buf + len), (size - len),
  320. DUMP_REG_VALUE(DSI_COMMAND_MODE_MDP_CTRL));
  321. len += snprintf((buf + len), (size - len),
  322. DUMP_REG_VALUE(DSI_COMMAND_MODE_MDP_DCS_CMD_CTRL));
  323. len += snprintf((buf + len), (size - len),
  324. DUMP_REG_VALUE(DSI_DMA_CMD_OFFSET));
  325. len += snprintf((buf + len), (size - len),
  326. DUMP_REG_VALUE(DSI_DMA_CMD_LENGTH));
  327. len += snprintf((buf + len), (size - len),
  328. DUMP_REG_VALUE(DSI_DMA_FIFO_CTRL));
  329. len += snprintf((buf + len), (size - len),
  330. DUMP_REG_VALUE(DSI_DMA_NULL_PACKET_DATA));
  331. len += snprintf((buf + len), (size - len),
  332. DUMP_REG_VALUE(DSI_COMMAND_MODE_MDP_STREAM0_CTRL));
  333. len += snprintf((buf + len), (size - len),
  334. DUMP_REG_VALUE(DSI_COMMAND_MODE_MDP_STREAM0_TOTAL));
  335. len += snprintf((buf + len), (size - len),
  336. DUMP_REG_VALUE(DSI_COMMAND_MODE_MDP_STREAM1_CTRL));
  337. len += snprintf((buf + len), (size - len),
  338. DUMP_REG_VALUE(DSI_COMMAND_MODE_MDP_STREAM1_TOTAL));
  339. len += snprintf((buf + len), (size - len),
  340. DUMP_REG_VALUE(DSI_ACK_ERR_STATUS));
  341. len += snprintf((buf + len), (size - len),
  342. DUMP_REG_VALUE(DSI_RDBK_DATA0));
  343. len += snprintf((buf + len), (size - len),
  344. DUMP_REG_VALUE(DSI_RDBK_DATA1));
  345. len += snprintf((buf + len), (size - len),
  346. DUMP_REG_VALUE(DSI_RDBK_DATA2));
  347. len += snprintf((buf + len), (size - len),
  348. DUMP_REG_VALUE(DSI_RDBK_DATA3));
  349. len += snprintf((buf + len), (size - len),
  350. DUMP_REG_VALUE(DSI_RDBK_DATATYPE0));
  351. len += snprintf((buf + len), (size - len),
  352. DUMP_REG_VALUE(DSI_RDBK_DATATYPE1));
  353. len += snprintf((buf + len), (size - len),
  354. DUMP_REG_VALUE(DSI_TRIG_CTRL));
  355. len += snprintf((buf + len), (size - len),
  356. DUMP_REG_VALUE(DSI_EXT_MUX));
  357. len += snprintf((buf + len), (size - len),
  358. DUMP_REG_VALUE(DSI_EXT_MUX_TE_PULSE_DETECT_CTRL));
  359. len += snprintf((buf + len), (size - len),
  360. DUMP_REG_VALUE(DSI_CMD_MODE_DMA_SW_TRIGGER));
  361. len += snprintf((buf + len), (size - len),
  362. DUMP_REG_VALUE(DSI_CMD_MODE_MDP_SW_TRIGGER));
  363. len += snprintf((buf + len), (size - len),
  364. DUMP_REG_VALUE(DSI_CMD_MODE_BTA_SW_TRIGGER));
  365. len += snprintf((buf + len), (size - len),
  366. DUMP_REG_VALUE(DSI_RESET_SW_TRIGGER));
  367. len += snprintf((buf + len), (size - len),
  368. DUMP_REG_VALUE(DSI_LANE_STATUS));
  369. len += snprintf((buf + len), (size - len),
  370. DUMP_REG_VALUE(DSI_LANE_CTRL));
  371. len += snprintf((buf + len), (size - len),
  372. DUMP_REG_VALUE(DSI_LANE_SWAP_CTRL));
  373. len += snprintf((buf + len), (size - len),
  374. DUMP_REG_VALUE(DSI_DLN0_PHY_ERR));
  375. len += snprintf((buf + len), (size - len),
  376. DUMP_REG_VALUE(DSI_LP_TIMER_CTRL));
  377. len += snprintf((buf + len), (size - len),
  378. DUMP_REG_VALUE(DSI_HS_TIMER_CTRL));
  379. len += snprintf((buf + len), (size - len),
  380. DUMP_REG_VALUE(DSI_TIMEOUT_STATUS));
  381. len += snprintf((buf + len), (size - len),
  382. DUMP_REG_VALUE(DSI_CLKOUT_TIMING_CTRL));
  383. len += snprintf((buf + len), (size - len),
  384. DUMP_REG_VALUE(DSI_EOT_PACKET));
  385. len += snprintf((buf + len), (size - len),
  386. DUMP_REG_VALUE(DSI_EOT_PACKET_CTRL));
  387. len += snprintf((buf + len), (size - len),
  388. DUMP_REG_VALUE(DSI_GENERIC_ESC_TX_TRIGGER));
  389. len += snprintf((buf + len), (size - len),
  390. DUMP_REG_VALUE(DSI_ERR_INT_MASK0));
  391. len += snprintf((buf + len), (size - len),
  392. DUMP_REG_VALUE(DSI_INT_CTRL));
  393. len += snprintf((buf + len), (size - len),
  394. DUMP_REG_VALUE(DSI_SOFT_RESET));
  395. len += snprintf((buf + len), (size - len),
  396. DUMP_REG_VALUE(DSI_CLK_CTRL));
  397. len += snprintf((buf + len), (size - len),
  398. DUMP_REG_VALUE(DSI_CLK_STATUS));
  399. len += snprintf((buf + len), (size - len),
  400. DUMP_REG_VALUE(DSI_PHY_SW_RESET));
  401. len += snprintf((buf + len), (size - len),
  402. DUMP_REG_VALUE(DSI_AXI2AHB_CTRL));
  403. len += snprintf((buf + len), (size - len),
  404. DUMP_REG_VALUE(DSI_COMMAND_MODE_MDP_CTRL2));
  405. len += snprintf((buf + len), (size - len),
  406. DUMP_REG_VALUE(DSI_COMMAND_MODE_MDP_STREAM2_CTRL));
  407. len += snprintf((buf + len), (size - len),
  408. DUMP_REG_VALUE(DSI_COMMAND_MODE_MDP_STREAM2_TOTAL));
  409. len += snprintf((buf + len), (size - len),
  410. DUMP_REG_VALUE(DSI_VBIF_CTRL));
  411. len += snprintf((buf + len), (size - len),
  412. DUMP_REG_VALUE(DSI_AES_CTRL));
  413. len += snprintf((buf + len), (size - len),
  414. DUMP_REG_VALUE(DSI_RDBK_DATA_CTRL));
  415. len += snprintf((buf + len), (size - len),
  416. DUMP_REG_VALUE(DSI_TEST_PATTERN_GEN_CMD_DMA_INIT_VAL2));
  417. len += snprintf((buf + len), (size - len),
  418. DUMP_REG_VALUE(DSI_TPG_DMA_FIFO_STATUS));
  419. len += snprintf((buf + len), (size - len),
  420. DUMP_REG_VALUE(DSI_TPG_DMA_FIFO_WRITE_TRIGGER));
  421. len += snprintf((buf + len), (size - len),
  422. DUMP_REG_VALUE(DSI_DSI_TIMING_FLUSH));
  423. len += snprintf((buf + len), (size - len),
  424. DUMP_REG_VALUE(DSI_DSI_TIMING_DB_MODE));
  425. len += snprintf((buf + len), (size - len),
  426. DUMP_REG_VALUE(DSI_TPG_DMA_FIFO_RESET));
  427. len += snprintf((buf + len), (size - len),
  428. DUMP_REG_VALUE(DSI_VERSION));
  429. pr_err("LLENGTH = %d\n", len);
  430. return len;
  431. }