mtk_dsi.c 34 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2015 MediaTek Inc.
  4. */
  5. #include <linux/bitfield.h>
  6. #include <linux/clk.h>
  7. #include <linux/component.h>
  8. #include <linux/iopoll.h>
  9. #include <linux/irq.h>
  10. #include <linux/of.h>
  11. #include <linux/of_platform.h>
  12. #include <linux/phy/phy.h>
  13. #include <linux/platform_device.h>
  14. #include <linux/reset.h>
  15. #include <linux/units.h>
  16. #include <video/mipi_display.h>
  17. #include <video/videomode.h>
  18. #include <drm/drm_atomic_helper.h>
  19. #include <drm/drm_bridge.h>
  20. #include <drm/drm_bridge_connector.h>
  21. #include <drm/drm_mipi_dsi.h>
  22. #include <drm/drm_of.h>
  23. #include <drm/drm_panel.h>
  24. #include <drm/drm_print.h>
  25. #include <drm/drm_probe_helper.h>
  26. #include <drm/drm_simple_kms_helper.h>
  27. #include "mtk_ddp_comp.h"
  28. #include "mtk_disp_drv.h"
  29. #include "mtk_drm_drv.h"
  30. #define DSI_START 0x00
  31. #define DSI_INTEN 0x08
  32. #define DSI_INTSTA 0x0c
  33. #define LPRX_RD_RDY_INT_FLAG BIT(0)
  34. #define CMD_DONE_INT_FLAG BIT(1)
  35. #define TE_RDY_INT_FLAG BIT(2)
  36. #define VM_DONE_INT_FLAG BIT(3)
  37. #define EXT_TE_RDY_INT_FLAG BIT(4)
  38. #define DSI_BUSY BIT(31)
  39. #define DSI_CON_CTRL 0x10
  40. #define DSI_RESET BIT(0)
  41. #define DSI_EN BIT(1)
  42. #define DPHY_RESET BIT(2)
  43. #define DSI_MODE_CTRL 0x14
  44. #define MODE (3)
  45. #define CMD_MODE 0
  46. #define SYNC_PULSE_MODE 1
  47. #define SYNC_EVENT_MODE 2
  48. #define BURST_MODE 3
  49. #define FRM_MODE BIT(16)
  50. #define MIX_MODE BIT(17)
  51. #define DSI_TXRX_CTRL 0x18
  52. #define VC_NUM BIT(1)
  53. #define LANE_NUM GENMASK(5, 2)
  54. #define DIS_EOT BIT(6)
  55. #define NULL_EN BIT(7)
  56. #define TE_FREERUN BIT(8)
  57. #define EXT_TE_EN BIT(9)
  58. #define EXT_TE_EDGE BIT(10)
  59. #define MAX_RTN_SIZE GENMASK(15, 12)
  60. #define HSTX_CKLP_EN BIT(16)
  61. #define DSI_PSCTRL 0x1c
  62. #define DSI_PS_WC GENMASK(13, 0)
  63. #define DSI_PS_SEL GENMASK(17, 16)
  64. #define PACKED_PS_16BIT_RGB565 0
  65. #define PACKED_PS_18BIT_RGB666 1
  66. #define LOOSELY_PS_24BIT_RGB666 2
  67. #define PACKED_PS_24BIT_RGB888 3
  68. #define DSI_VSA_NL 0x20
  69. #define DSI_VBP_NL 0x24
  70. #define DSI_VFP_NL 0x28
  71. #define DSI_VACT_NL 0x2C
  72. #define VACT_NL GENMASK(14, 0)
  73. #define DSI_SIZE_CON 0x38
  74. #define DSI_HEIGHT GENMASK(30, 16)
  75. #define DSI_WIDTH GENMASK(14, 0)
  76. #define DSI_HSA_WC 0x50
  77. #define DSI_HBP_WC 0x54
  78. #define DSI_HFP_WC 0x58
  79. #define HFP_HS_VB_PS_WC GENMASK(30, 16)
  80. #define HFP_HS_EN BIT(31)
  81. #define DSI_CMDQ_SIZE 0x60
  82. #define CMDQ_SIZE 0x3f
  83. #define CMDQ_SIZE_SEL BIT(15)
  84. #define DSI_HSTX_CKL_WC 0x64
  85. #define HSTX_CKL_WC GENMASK(15, 2)
  86. #define DSI_RX_DATA0 0x74
  87. #define DSI_RX_DATA1 0x78
  88. #define DSI_RX_DATA2 0x7c
  89. #define DSI_RX_DATA3 0x80
  90. #define DSI_RACK 0x84
  91. #define RACK BIT(0)
  92. #define DSI_PHY_LCCON 0x104
  93. #define LC_HS_TX_EN BIT(0)
  94. #define LC_ULPM_EN BIT(1)
  95. #define LC_WAKEUP_EN BIT(2)
  96. #define DSI_PHY_LD0CON 0x108
  97. #define LD0_HS_TX_EN BIT(0)
  98. #define LD0_ULPM_EN BIT(1)
  99. #define LD0_WAKEUP_EN BIT(2)
  100. #define DSI_PHY_TIMECON0 0x110
  101. #define LPX GENMASK(7, 0)
  102. #define HS_PREP GENMASK(15, 8)
  103. #define HS_ZERO GENMASK(23, 16)
  104. #define HS_TRAIL GENMASK(31, 24)
  105. #define DSI_PHY_TIMECON1 0x114
  106. #define TA_GO GENMASK(7, 0)
  107. #define TA_SURE GENMASK(15, 8)
  108. #define TA_GET GENMASK(23, 16)
  109. #define DA_HS_EXIT GENMASK(31, 24)
  110. #define DSI_PHY_TIMECON2 0x118
  111. #define CONT_DET GENMASK(7, 0)
  112. #define DA_HS_SYNC GENMASK(15, 8)
  113. #define CLK_ZERO GENMASK(23, 16)
  114. #define CLK_TRAIL GENMASK(31, 24)
  115. #define DSI_PHY_TIMECON3 0x11c
  116. #define CLK_HS_PREP GENMASK(7, 0)
  117. #define CLK_HS_POST GENMASK(15, 8)
  118. #define CLK_HS_EXIT GENMASK(23, 16)
  119. /* DSI_VM_CMD_CON */
  120. #define VM_CMD_EN BIT(0)
  121. #define TS_VFP_EN BIT(5)
  122. /* DSI_SHADOW_DEBUG */
  123. #define FORCE_COMMIT BIT(0)
  124. #define BYPASS_SHADOW BIT(1)
  125. /* CMDQ related bits */
  126. #define CONFIG GENMASK(7, 0)
  127. #define SHORT_PACKET 0
  128. #define LONG_PACKET 2
  129. #define BTA BIT(2)
  130. #define HSTX BIT(3)
  131. #define DATA_ID GENMASK(15, 8)
  132. #define DATA_0 GENMASK(23, 16)
  133. #define DATA_1 GENMASK(31, 24)
  134. #define NS_TO_CYCLE(n, c) ((n) / (c) + (((n) % (c)) ? 1 : 0))
  135. #define MTK_DSI_HOST_IS_READ(type) \
  136. ((type == MIPI_DSI_GENERIC_READ_REQUEST_0_PARAM) || \
  137. (type == MIPI_DSI_GENERIC_READ_REQUEST_1_PARAM) || \
  138. (type == MIPI_DSI_GENERIC_READ_REQUEST_2_PARAM) || \
  139. (type == MIPI_DSI_DCS_READ))
  140. struct mtk_phy_timing {
  141. u32 lpx;
  142. u32 da_hs_prepare;
  143. u32 da_hs_zero;
  144. u32 da_hs_trail;
  145. u32 ta_go;
  146. u32 ta_sure;
  147. u32 ta_get;
  148. u32 da_hs_exit;
  149. u32 clk_hs_zero;
  150. u32 clk_hs_trail;
  151. u32 clk_hs_prepare;
  152. u32 clk_hs_post;
  153. u32 clk_hs_exit;
  154. };
  155. struct phy;
  156. struct mtk_dsi_driver_data {
  157. const u32 reg_cmdq_off;
  158. const u32 reg_vm_cmd_off;
  159. const u32 reg_shadow_dbg_off;
  160. bool has_shadow_ctl;
  161. bool has_size_ctl;
  162. bool cmdq_long_packet_ctl;
  163. bool support_per_frame_lp;
  164. };
  165. struct mtk_dsi {
  166. struct device *dev;
  167. struct mipi_dsi_host host;
  168. struct drm_encoder encoder;
  169. struct drm_bridge bridge;
  170. struct drm_bridge *next_bridge;
  171. struct drm_connector *connector;
  172. struct phy *phy;
  173. void __iomem *regs;
  174. struct clk *engine_clk;
  175. struct clk *digital_clk;
  176. struct clk *hs_clk;
  177. u32 data_rate;
  178. unsigned long mode_flags;
  179. enum mipi_dsi_pixel_format format;
  180. unsigned int lanes;
  181. struct videomode vm;
  182. struct mtk_phy_timing phy_timing;
  183. int refcount;
  184. bool enabled;
  185. bool lanes_ready;
  186. u32 irq_data;
  187. wait_queue_head_t irq_wait_queue;
  188. const struct mtk_dsi_driver_data *driver_data;
  189. };
  190. static inline struct mtk_dsi *bridge_to_dsi(struct drm_bridge *b)
  191. {
  192. return container_of(b, struct mtk_dsi, bridge);
  193. }
  194. static inline struct mtk_dsi *host_to_dsi(struct mipi_dsi_host *h)
  195. {
  196. return container_of(h, struct mtk_dsi, host);
  197. }
  198. static void mtk_dsi_mask(struct mtk_dsi *dsi, u32 offset, u32 mask, u32 data)
  199. {
  200. u32 temp = readl(dsi->regs + offset);
  201. writel((temp & ~mask) | (data & mask), dsi->regs + offset);
  202. }
  203. static void mtk_dsi_phy_timconfig(struct mtk_dsi *dsi)
  204. {
  205. u32 timcon0, timcon1, timcon2, timcon3;
  206. u32 data_rate_mhz = DIV_ROUND_UP(dsi->data_rate, HZ_PER_MHZ);
  207. struct mtk_phy_timing *timing = &dsi->phy_timing;
  208. timing->lpx = (60 * data_rate_mhz / (8 * 1000)) + 1;
  209. timing->da_hs_prepare = (80 * data_rate_mhz + 4 * 1000) / 8000;
  210. timing->da_hs_zero = (170 * data_rate_mhz + 10 * 1000) / 8000 + 1 -
  211. timing->da_hs_prepare;
  212. timing->da_hs_trail = timing->da_hs_prepare + 1;
  213. timing->ta_go = 4 * timing->lpx - 2;
  214. timing->ta_sure = timing->lpx + 2;
  215. timing->ta_get = 4 * timing->lpx;
  216. timing->da_hs_exit = 2 * timing->lpx + 1;
  217. timing->clk_hs_prepare = 70 * data_rate_mhz / (8 * 1000);
  218. timing->clk_hs_post = timing->clk_hs_prepare + 8;
  219. timing->clk_hs_trail = timing->clk_hs_prepare;
  220. timing->clk_hs_zero = timing->clk_hs_trail * 4;
  221. timing->clk_hs_exit = 2 * timing->clk_hs_trail;
  222. timcon0 = FIELD_PREP(LPX, timing->lpx) |
  223. FIELD_PREP(HS_PREP, timing->da_hs_prepare) |
  224. FIELD_PREP(HS_ZERO, timing->da_hs_zero) |
  225. FIELD_PREP(HS_TRAIL, timing->da_hs_trail);
  226. timcon1 = FIELD_PREP(TA_GO, timing->ta_go) |
  227. FIELD_PREP(TA_SURE, timing->ta_sure) |
  228. FIELD_PREP(TA_GET, timing->ta_get) |
  229. FIELD_PREP(DA_HS_EXIT, timing->da_hs_exit);
  230. timcon2 = FIELD_PREP(DA_HS_SYNC, 1) |
  231. FIELD_PREP(CLK_ZERO, timing->clk_hs_zero) |
  232. FIELD_PREP(CLK_TRAIL, timing->clk_hs_trail);
  233. timcon3 = FIELD_PREP(CLK_HS_PREP, timing->clk_hs_prepare) |
  234. FIELD_PREP(CLK_HS_POST, timing->clk_hs_post) |
  235. FIELD_PREP(CLK_HS_EXIT, timing->clk_hs_exit);
  236. writel(timcon0, dsi->regs + DSI_PHY_TIMECON0);
  237. writel(timcon1, dsi->regs + DSI_PHY_TIMECON1);
  238. writel(timcon2, dsi->regs + DSI_PHY_TIMECON2);
  239. writel(timcon3, dsi->regs + DSI_PHY_TIMECON3);
  240. }
  241. static void mtk_dsi_enable(struct mtk_dsi *dsi)
  242. {
  243. mtk_dsi_mask(dsi, DSI_CON_CTRL, DSI_EN, DSI_EN);
  244. }
  245. static void mtk_dsi_disable(struct mtk_dsi *dsi)
  246. {
  247. mtk_dsi_mask(dsi, DSI_CON_CTRL, DSI_EN, 0);
  248. }
  249. static void mtk_dsi_reset_engine(struct mtk_dsi *dsi)
  250. {
  251. mtk_dsi_mask(dsi, DSI_CON_CTRL, DSI_RESET, DSI_RESET);
  252. mtk_dsi_mask(dsi, DSI_CON_CTRL, DSI_RESET, 0);
  253. }
  254. static void mtk_dsi_reset_dphy(struct mtk_dsi *dsi)
  255. {
  256. mtk_dsi_mask(dsi, DSI_CON_CTRL, DPHY_RESET, DPHY_RESET);
  257. mtk_dsi_mask(dsi, DSI_CON_CTRL, DPHY_RESET, 0);
  258. }
  259. static void mtk_dsi_clk_ulp_mode_enter(struct mtk_dsi *dsi)
  260. {
  261. mtk_dsi_mask(dsi, DSI_PHY_LCCON, LC_HS_TX_EN, 0);
  262. mtk_dsi_mask(dsi, DSI_PHY_LCCON, LC_ULPM_EN, 0);
  263. }
  264. static void mtk_dsi_clk_ulp_mode_leave(struct mtk_dsi *dsi)
  265. {
  266. mtk_dsi_mask(dsi, DSI_PHY_LCCON, LC_ULPM_EN, 0);
  267. mtk_dsi_mask(dsi, DSI_PHY_LCCON, LC_WAKEUP_EN, LC_WAKEUP_EN);
  268. mtk_dsi_mask(dsi, DSI_PHY_LCCON, LC_WAKEUP_EN, 0);
  269. }
  270. static void mtk_dsi_lane0_ulp_mode_enter(struct mtk_dsi *dsi)
  271. {
  272. mtk_dsi_mask(dsi, DSI_PHY_LD0CON, LD0_HS_TX_EN, 0);
  273. mtk_dsi_mask(dsi, DSI_PHY_LD0CON, LD0_ULPM_EN, 0);
  274. }
  275. static void mtk_dsi_lane0_ulp_mode_leave(struct mtk_dsi *dsi)
  276. {
  277. mtk_dsi_mask(dsi, DSI_PHY_LD0CON, LD0_ULPM_EN, 0);
  278. mtk_dsi_mask(dsi, DSI_PHY_LD0CON, LD0_WAKEUP_EN, LD0_WAKEUP_EN);
  279. mtk_dsi_mask(dsi, DSI_PHY_LD0CON, LD0_WAKEUP_EN, 0);
  280. }
  281. static bool mtk_dsi_clk_hs_state(struct mtk_dsi *dsi)
  282. {
  283. return readl(dsi->regs + DSI_PHY_LCCON) & LC_HS_TX_EN;
  284. }
  285. static void mtk_dsi_clk_hs_mode(struct mtk_dsi *dsi, bool enter)
  286. {
  287. if (enter && !mtk_dsi_clk_hs_state(dsi))
  288. mtk_dsi_mask(dsi, DSI_PHY_LCCON, LC_HS_TX_EN, LC_HS_TX_EN);
  289. else if (!enter && mtk_dsi_clk_hs_state(dsi))
  290. mtk_dsi_mask(dsi, DSI_PHY_LCCON, LC_HS_TX_EN, 0);
  291. }
  292. static void mtk_dsi_set_mode(struct mtk_dsi *dsi)
  293. {
  294. u32 vid_mode = CMD_MODE;
  295. if (dsi->mode_flags & MIPI_DSI_MODE_VIDEO) {
  296. if (dsi->mode_flags & MIPI_DSI_MODE_VIDEO_BURST)
  297. vid_mode = BURST_MODE;
  298. else if (dsi->mode_flags & MIPI_DSI_MODE_VIDEO_SYNC_PULSE)
  299. vid_mode = SYNC_PULSE_MODE;
  300. else
  301. vid_mode = SYNC_EVENT_MODE;
  302. }
  303. writel(vid_mode, dsi->regs + DSI_MODE_CTRL);
  304. }
  305. static void mtk_dsi_set_vm_cmd(struct mtk_dsi *dsi)
  306. {
  307. mtk_dsi_mask(dsi, dsi->driver_data->reg_vm_cmd_off, VM_CMD_EN, VM_CMD_EN);
  308. mtk_dsi_mask(dsi, dsi->driver_data->reg_vm_cmd_off, TS_VFP_EN, TS_VFP_EN);
  309. }
  310. static void mtk_dsi_rxtx_control(struct mtk_dsi *dsi)
  311. {
  312. u32 regval, tmp_reg = 0;
  313. u8 i;
  314. /* Number of DSI lanes (max 4 lanes), each bit enables one DSI lane. */
  315. for (i = 0; i < dsi->lanes; i++)
  316. tmp_reg |= BIT(i);
  317. regval = FIELD_PREP(LANE_NUM, tmp_reg);
  318. if (dsi->mode_flags & MIPI_DSI_CLOCK_NON_CONTINUOUS)
  319. regval |= HSTX_CKLP_EN;
  320. if (dsi->mode_flags & MIPI_DSI_MODE_NO_EOT_PACKET)
  321. regval |= DIS_EOT;
  322. writel(regval, dsi->regs + DSI_TXRX_CTRL);
  323. }
  324. static void mtk_dsi_ps_control(struct mtk_dsi *dsi, bool config_vact)
  325. {
  326. u32 dsi_buf_bpp, ps_val, ps_wc, vact_nl;
  327. if (dsi->format == MIPI_DSI_FMT_RGB565)
  328. dsi_buf_bpp = 2;
  329. else
  330. dsi_buf_bpp = 3;
  331. /* Word count */
  332. ps_wc = FIELD_PREP(DSI_PS_WC, dsi->vm.hactive * dsi_buf_bpp);
  333. ps_val = ps_wc;
  334. /* Pixel Stream type */
  335. switch (dsi->format) {
  336. default:
  337. fallthrough;
  338. case MIPI_DSI_FMT_RGB888:
  339. ps_val |= FIELD_PREP(DSI_PS_SEL, PACKED_PS_24BIT_RGB888);
  340. break;
  341. case MIPI_DSI_FMT_RGB666:
  342. ps_val |= FIELD_PREP(DSI_PS_SEL, LOOSELY_PS_24BIT_RGB666);
  343. break;
  344. case MIPI_DSI_FMT_RGB666_PACKED:
  345. ps_val |= FIELD_PREP(DSI_PS_SEL, PACKED_PS_18BIT_RGB666);
  346. break;
  347. case MIPI_DSI_FMT_RGB565:
  348. ps_val |= FIELD_PREP(DSI_PS_SEL, PACKED_PS_16BIT_RGB565);
  349. break;
  350. }
  351. if (config_vact) {
  352. vact_nl = FIELD_PREP(VACT_NL, dsi->vm.vactive);
  353. writel(vact_nl, dsi->regs + DSI_VACT_NL);
  354. writel(ps_wc, dsi->regs + DSI_HSTX_CKL_WC);
  355. }
  356. writel(ps_val, dsi->regs + DSI_PSCTRL);
  357. }
  358. static void mtk_dsi_config_vdo_timing_per_frame_lp(struct mtk_dsi *dsi)
  359. {
  360. u32 horizontal_sync_active_byte;
  361. u32 horizontal_backporch_byte;
  362. u32 horizontal_frontporch_byte;
  363. u32 hfp_byte_adjust, v_active_adjust;
  364. u32 cklp_wc_min_adjust, cklp_wc_max_adjust;
  365. u32 dsi_tmp_buf_bpp;
  366. unsigned int da_hs_trail;
  367. unsigned int ps_wc, hs_vb_ps_wc;
  368. u32 v_active_roundup, hstx_cklp_wc;
  369. u32 hstx_cklp_wc_max, hstx_cklp_wc_min;
  370. struct videomode *vm = &dsi->vm;
  371. if (dsi->format == MIPI_DSI_FMT_RGB565)
  372. dsi_tmp_buf_bpp = 2;
  373. else
  374. dsi_tmp_buf_bpp = 3;
  375. da_hs_trail = dsi->phy_timing.da_hs_trail;
  376. ps_wc = vm->hactive * dsi_tmp_buf_bpp;
  377. if (dsi->mode_flags & MIPI_DSI_MODE_VIDEO_SYNC_PULSE) {
  378. horizontal_sync_active_byte =
  379. vm->hsync_len * dsi_tmp_buf_bpp - 10;
  380. horizontal_backporch_byte =
  381. vm->hback_porch * dsi_tmp_buf_bpp - 10;
  382. hfp_byte_adjust = 12;
  383. v_active_adjust = 32 + horizontal_sync_active_byte;
  384. cklp_wc_min_adjust = 12 + 2 + 4 + horizontal_sync_active_byte;
  385. cklp_wc_max_adjust = 20 + 6 + 4 + horizontal_sync_active_byte;
  386. } else {
  387. horizontal_sync_active_byte = vm->hsync_len * dsi_tmp_buf_bpp - 4;
  388. horizontal_backporch_byte = (vm->hback_porch + vm->hsync_len) *
  389. dsi_tmp_buf_bpp - 10;
  390. cklp_wc_min_adjust = 4;
  391. cklp_wc_max_adjust = 12 + 4 + 4;
  392. if (dsi->mode_flags & MIPI_DSI_MODE_VIDEO_BURST) {
  393. hfp_byte_adjust = 18;
  394. v_active_adjust = 28;
  395. } else {
  396. hfp_byte_adjust = 12;
  397. v_active_adjust = 22;
  398. }
  399. }
  400. horizontal_frontporch_byte = vm->hfront_porch * dsi_tmp_buf_bpp - hfp_byte_adjust;
  401. v_active_roundup = (v_active_adjust + horizontal_backporch_byte + ps_wc +
  402. horizontal_frontporch_byte) % dsi->lanes;
  403. if (v_active_roundup)
  404. horizontal_backporch_byte += dsi->lanes - v_active_roundup;
  405. hstx_cklp_wc_min = (DIV_ROUND_UP(cklp_wc_min_adjust, dsi->lanes) + da_hs_trail + 1)
  406. * dsi->lanes / 6 - 1;
  407. hstx_cklp_wc_max = (DIV_ROUND_UP((cklp_wc_max_adjust + horizontal_backporch_byte +
  408. ps_wc), dsi->lanes) + da_hs_trail + 1) * dsi->lanes / 6 - 1;
  409. hstx_cklp_wc = FIELD_PREP(HSTX_CKL_WC, (hstx_cklp_wc_min + hstx_cklp_wc_max) / 2);
  410. writel(hstx_cklp_wc, dsi->regs + DSI_HSTX_CKL_WC);
  411. hs_vb_ps_wc = ps_wc - (dsi->phy_timing.lpx + dsi->phy_timing.da_hs_exit +
  412. dsi->phy_timing.da_hs_prepare + dsi->phy_timing.da_hs_zero + 2) * dsi->lanes;
  413. horizontal_frontporch_byte |= FIELD_PREP(HFP_HS_EN, 1) |
  414. FIELD_PREP(HFP_HS_VB_PS_WC, hs_vb_ps_wc);
  415. writel(horizontal_sync_active_byte, dsi->regs + DSI_HSA_WC);
  416. writel(horizontal_backporch_byte, dsi->regs + DSI_HBP_WC);
  417. writel(horizontal_frontporch_byte, dsi->regs + DSI_HFP_WC);
  418. }
  419. static void mtk_dsi_config_vdo_timing_per_line_lp(struct mtk_dsi *dsi)
  420. {
  421. u32 horizontal_sync_active_byte;
  422. u32 horizontal_backporch_byte;
  423. u32 horizontal_frontporch_byte;
  424. u32 horizontal_front_back_byte;
  425. u32 data_phy_cycles_byte;
  426. u32 dsi_tmp_buf_bpp, data_phy_cycles;
  427. u32 delta;
  428. struct mtk_phy_timing *timing = &dsi->phy_timing;
  429. struct videomode *vm = &dsi->vm;
  430. if (dsi->format == MIPI_DSI_FMT_RGB565)
  431. dsi_tmp_buf_bpp = 2;
  432. else
  433. dsi_tmp_buf_bpp = 3;
  434. horizontal_sync_active_byte = (vm->hsync_len * dsi_tmp_buf_bpp - 10);
  435. if (dsi->mode_flags & MIPI_DSI_MODE_VIDEO_SYNC_PULSE)
  436. horizontal_backporch_byte = vm->hback_porch * dsi_tmp_buf_bpp - 10;
  437. else
  438. horizontal_backporch_byte = (vm->hback_porch + vm->hsync_len) *
  439. dsi_tmp_buf_bpp - 10;
  440. data_phy_cycles = timing->lpx + timing->da_hs_prepare +
  441. timing->da_hs_zero + timing->da_hs_exit + 3;
  442. delta = dsi->mode_flags & MIPI_DSI_MODE_VIDEO_BURST ? 18 : 12;
  443. delta += dsi->mode_flags & MIPI_DSI_MODE_NO_EOT_PACKET ? 0 : 2;
  444. horizontal_frontporch_byte = vm->hfront_porch * dsi_tmp_buf_bpp;
  445. horizontal_front_back_byte = horizontal_frontporch_byte + horizontal_backporch_byte;
  446. data_phy_cycles_byte = data_phy_cycles * dsi->lanes + delta;
  447. if (horizontal_front_back_byte > data_phy_cycles_byte) {
  448. horizontal_frontporch_byte -= data_phy_cycles_byte *
  449. horizontal_frontporch_byte /
  450. horizontal_front_back_byte;
  451. horizontal_backporch_byte -= data_phy_cycles_byte *
  452. horizontal_backporch_byte /
  453. horizontal_front_back_byte;
  454. } else {
  455. DRM_WARN("HFP + HBP less than d-phy, FPS will under 60Hz\n");
  456. }
  457. if ((dsi->mode_flags & MIPI_DSI_HS_PKT_END_ALIGNED) &&
  458. (dsi->lanes == 4)) {
  459. horizontal_sync_active_byte =
  460. roundup(horizontal_sync_active_byte, dsi->lanes) - 2;
  461. horizontal_frontporch_byte =
  462. roundup(horizontal_frontporch_byte, dsi->lanes) - 2;
  463. horizontal_backporch_byte =
  464. roundup(horizontal_backporch_byte, dsi->lanes) - 2;
  465. horizontal_backporch_byte -=
  466. (vm->hactive * dsi_tmp_buf_bpp + 2) % dsi->lanes;
  467. }
  468. writel(horizontal_sync_active_byte, dsi->regs + DSI_HSA_WC);
  469. writel(horizontal_backporch_byte, dsi->regs + DSI_HBP_WC);
  470. writel(horizontal_frontporch_byte, dsi->regs + DSI_HFP_WC);
  471. }
  472. static void mtk_dsi_config_vdo_timing(struct mtk_dsi *dsi)
  473. {
  474. struct videomode *vm = &dsi->vm;
  475. writel(vm->vsync_len, dsi->regs + DSI_VSA_NL);
  476. writel(vm->vback_porch, dsi->regs + DSI_VBP_NL);
  477. writel(vm->vfront_porch, dsi->regs + DSI_VFP_NL);
  478. writel(vm->vactive, dsi->regs + DSI_VACT_NL);
  479. if (dsi->driver_data->has_size_ctl)
  480. writel(FIELD_PREP(DSI_HEIGHT, vm->vactive) |
  481. FIELD_PREP(DSI_WIDTH, vm->hactive),
  482. dsi->regs + DSI_SIZE_CON);
  483. if (dsi->driver_data->support_per_frame_lp)
  484. mtk_dsi_config_vdo_timing_per_frame_lp(dsi);
  485. else
  486. mtk_dsi_config_vdo_timing_per_line_lp(dsi);
  487. mtk_dsi_ps_control(dsi, false);
  488. }
  489. static void mtk_dsi_start(struct mtk_dsi *dsi)
  490. {
  491. writel(0, dsi->regs + DSI_START);
  492. writel(1, dsi->regs + DSI_START);
  493. }
  494. static void mtk_dsi_stop(struct mtk_dsi *dsi)
  495. {
  496. writel(0, dsi->regs + DSI_START);
  497. }
  498. static void mtk_dsi_set_cmd_mode(struct mtk_dsi *dsi)
  499. {
  500. writel(CMD_MODE, dsi->regs + DSI_MODE_CTRL);
  501. }
  502. static void mtk_dsi_set_interrupt_enable(struct mtk_dsi *dsi)
  503. {
  504. u32 inten = LPRX_RD_RDY_INT_FLAG | CMD_DONE_INT_FLAG | VM_DONE_INT_FLAG;
  505. writel(inten, dsi->regs + DSI_INTEN);
  506. }
  507. static void mtk_dsi_irq_data_set(struct mtk_dsi *dsi, u32 irq_bit)
  508. {
  509. dsi->irq_data |= irq_bit;
  510. }
  511. static void mtk_dsi_irq_data_clear(struct mtk_dsi *dsi, u32 irq_bit)
  512. {
  513. dsi->irq_data &= ~irq_bit;
  514. }
  515. static s32 mtk_dsi_wait_for_irq_done(struct mtk_dsi *dsi, u32 irq_flag,
  516. unsigned int timeout)
  517. {
  518. s32 ret = 0;
  519. unsigned long jiffies = msecs_to_jiffies(timeout);
  520. ret = wait_event_interruptible_timeout(dsi->irq_wait_queue,
  521. dsi->irq_data & irq_flag,
  522. jiffies);
  523. if (ret == 0) {
  524. DRM_WARN("Wait DSI IRQ(0x%08x) Timeout\n", irq_flag);
  525. mtk_dsi_enable(dsi);
  526. mtk_dsi_reset_engine(dsi);
  527. }
  528. return ret;
  529. }
  530. static irqreturn_t mtk_dsi_irq(int irq, void *dev_id)
  531. {
  532. struct mtk_dsi *dsi = dev_id;
  533. u32 status, tmp;
  534. u32 flag = LPRX_RD_RDY_INT_FLAG | CMD_DONE_INT_FLAG | VM_DONE_INT_FLAG;
  535. status = readl(dsi->regs + DSI_INTSTA) & flag;
  536. if (status) {
  537. do {
  538. mtk_dsi_mask(dsi, DSI_RACK, RACK, RACK);
  539. tmp = readl(dsi->regs + DSI_INTSTA);
  540. } while (tmp & DSI_BUSY);
  541. mtk_dsi_mask(dsi, DSI_INTSTA, status, 0);
  542. mtk_dsi_irq_data_set(dsi, status);
  543. wake_up_interruptible(&dsi->irq_wait_queue);
  544. }
  545. return IRQ_HANDLED;
  546. }
  547. static s32 mtk_dsi_switch_to_cmd_mode(struct mtk_dsi *dsi, u8 irq_flag, u32 t)
  548. {
  549. mtk_dsi_irq_data_clear(dsi, irq_flag);
  550. mtk_dsi_set_cmd_mode(dsi);
  551. if (!mtk_dsi_wait_for_irq_done(dsi, irq_flag, t)) {
  552. DRM_ERROR("failed to switch cmd mode\n");
  553. return -ETIME;
  554. } else {
  555. return 0;
  556. }
  557. }
  558. static int mtk_dsi_poweron(struct mtk_dsi *dsi)
  559. {
  560. struct device *dev = dsi->host.dev;
  561. int ret;
  562. u32 bit_per_pixel;
  563. if (++dsi->refcount != 1)
  564. return 0;
  565. ret = mipi_dsi_pixel_format_to_bpp(dsi->format);
  566. if (ret < 0) {
  567. dev_err(dev, "Unknown MIPI DSI format %d\n", dsi->format);
  568. return ret;
  569. }
  570. bit_per_pixel = ret;
  571. dsi->data_rate = DIV_ROUND_UP_ULL(dsi->vm.pixelclock * bit_per_pixel,
  572. dsi->lanes);
  573. ret = clk_set_rate(dsi->hs_clk, dsi->data_rate);
  574. if (ret < 0) {
  575. dev_err(dev, "Failed to set data rate: %d\n", ret);
  576. goto err_refcount;
  577. }
  578. phy_power_on(dsi->phy);
  579. ret = clk_prepare_enable(dsi->engine_clk);
  580. if (ret < 0) {
  581. dev_err(dev, "Failed to enable engine clock: %d\n", ret);
  582. goto err_phy_power_off;
  583. }
  584. ret = clk_prepare_enable(dsi->digital_clk);
  585. if (ret < 0) {
  586. dev_err(dev, "Failed to enable digital clock: %d\n", ret);
  587. goto err_disable_engine_clk;
  588. }
  589. mtk_dsi_enable(dsi);
  590. if (dsi->driver_data->has_shadow_ctl)
  591. writel(FORCE_COMMIT | BYPASS_SHADOW,
  592. dsi->regs + dsi->driver_data->reg_shadow_dbg_off);
  593. mtk_dsi_reset_engine(dsi);
  594. mtk_dsi_phy_timconfig(dsi);
  595. mtk_dsi_ps_control(dsi, true);
  596. mtk_dsi_set_vm_cmd(dsi);
  597. mtk_dsi_config_vdo_timing(dsi);
  598. mtk_dsi_set_interrupt_enable(dsi);
  599. return 0;
  600. err_disable_engine_clk:
  601. clk_disable_unprepare(dsi->engine_clk);
  602. err_phy_power_off:
  603. phy_power_off(dsi->phy);
  604. err_refcount:
  605. dsi->refcount--;
  606. return ret;
  607. }
  608. static void mtk_dsi_poweroff(struct mtk_dsi *dsi)
  609. {
  610. if (WARN_ON(dsi->refcount == 0))
  611. return;
  612. if (--dsi->refcount != 0)
  613. return;
  614. /*
  615. * mtk_dsi_stop() and mtk_dsi_start() is asymmetric, since
  616. * mtk_dsi_stop() should be called after mtk_crtc_atomic_disable(),
  617. * which needs irq for vblank, and mtk_dsi_stop() will disable irq.
  618. * mtk_dsi_start() needs to be called in mtk_output_dsi_enable(),
  619. * after dsi is fully set.
  620. */
  621. mtk_dsi_stop(dsi);
  622. mtk_dsi_switch_to_cmd_mode(dsi, VM_DONE_INT_FLAG, 500);
  623. mtk_dsi_reset_engine(dsi);
  624. mtk_dsi_lane0_ulp_mode_enter(dsi);
  625. mtk_dsi_clk_ulp_mode_enter(dsi);
  626. /* set the lane number as 0 to pull down mipi */
  627. writel(0, dsi->regs + DSI_TXRX_CTRL);
  628. mtk_dsi_disable(dsi);
  629. clk_disable_unprepare(dsi->engine_clk);
  630. clk_disable_unprepare(dsi->digital_clk);
  631. phy_power_off(dsi->phy);
  632. dsi->lanes_ready = false;
  633. }
  634. static void mtk_dsi_lane_ready(struct mtk_dsi *dsi)
  635. {
  636. if (!dsi->lanes_ready) {
  637. dsi->lanes_ready = true;
  638. mtk_dsi_rxtx_control(dsi);
  639. usleep_range(30, 100);
  640. mtk_dsi_reset_dphy(dsi);
  641. mtk_dsi_clk_ulp_mode_leave(dsi);
  642. mtk_dsi_lane0_ulp_mode_leave(dsi);
  643. mtk_dsi_clk_hs_mode(dsi, 0);
  644. usleep_range(1000, 3000);
  645. /* The reaction time after pulling up the mipi signal for dsi_rx */
  646. }
  647. }
  648. static void mtk_output_dsi_enable(struct mtk_dsi *dsi)
  649. {
  650. if (dsi->enabled)
  651. return;
  652. mtk_dsi_lane_ready(dsi);
  653. mtk_dsi_set_mode(dsi);
  654. mtk_dsi_clk_hs_mode(dsi, 1);
  655. mtk_dsi_start(dsi);
  656. dsi->enabled = true;
  657. }
  658. static void mtk_output_dsi_disable(struct mtk_dsi *dsi)
  659. {
  660. if (!dsi->enabled)
  661. return;
  662. dsi->enabled = false;
  663. }
  664. static int mtk_dsi_bridge_attach(struct drm_bridge *bridge,
  665. struct drm_encoder *encoder,
  666. enum drm_bridge_attach_flags flags)
  667. {
  668. struct mtk_dsi *dsi = bridge_to_dsi(bridge);
  669. /* Attach the panel or bridge to the dsi bridge */
  670. return drm_bridge_attach(encoder, dsi->next_bridge,
  671. &dsi->bridge, flags);
  672. }
  673. static void mtk_dsi_bridge_mode_set(struct drm_bridge *bridge,
  674. const struct drm_display_mode *mode,
  675. const struct drm_display_mode *adjusted)
  676. {
  677. struct mtk_dsi *dsi = bridge_to_dsi(bridge);
  678. drm_display_mode_to_videomode(adjusted, &dsi->vm);
  679. }
  680. static void mtk_dsi_bridge_atomic_disable(struct drm_bridge *bridge,
  681. struct drm_atomic_state *state)
  682. {
  683. struct mtk_dsi *dsi = bridge_to_dsi(bridge);
  684. mtk_output_dsi_disable(dsi);
  685. }
  686. static void mtk_dsi_bridge_atomic_enable(struct drm_bridge *bridge,
  687. struct drm_atomic_state *state)
  688. {
  689. struct mtk_dsi *dsi = bridge_to_dsi(bridge);
  690. if (dsi->refcount == 0)
  691. return;
  692. mtk_output_dsi_enable(dsi);
  693. }
  694. static void mtk_dsi_bridge_atomic_pre_enable(struct drm_bridge *bridge,
  695. struct drm_atomic_state *state)
  696. {
  697. struct mtk_dsi *dsi = bridge_to_dsi(bridge);
  698. int ret;
  699. ret = mtk_dsi_poweron(dsi);
  700. if (ret < 0)
  701. DRM_ERROR("failed to power on dsi\n");
  702. }
  703. static void mtk_dsi_bridge_atomic_post_disable(struct drm_bridge *bridge,
  704. struct drm_atomic_state *state)
  705. {
  706. struct mtk_dsi *dsi = bridge_to_dsi(bridge);
  707. mtk_dsi_poweroff(dsi);
  708. }
  709. static enum drm_mode_status
  710. mtk_dsi_bridge_mode_valid(struct drm_bridge *bridge,
  711. const struct drm_display_info *info,
  712. const struct drm_display_mode *mode)
  713. {
  714. struct mtk_dsi *dsi = bridge_to_dsi(bridge);
  715. int bpp;
  716. bpp = mipi_dsi_pixel_format_to_bpp(dsi->format);
  717. if (bpp < 0)
  718. return MODE_ERROR;
  719. if (mode->clock * bpp / dsi->lanes > 1500000)
  720. return MODE_CLOCK_HIGH;
  721. return MODE_OK;
  722. }
  723. static const struct drm_bridge_funcs mtk_dsi_bridge_funcs = {
  724. .attach = mtk_dsi_bridge_attach,
  725. .atomic_destroy_state = drm_atomic_helper_bridge_destroy_state,
  726. .atomic_disable = mtk_dsi_bridge_atomic_disable,
  727. .atomic_duplicate_state = drm_atomic_helper_bridge_duplicate_state,
  728. .atomic_enable = mtk_dsi_bridge_atomic_enable,
  729. .atomic_pre_enable = mtk_dsi_bridge_atomic_pre_enable,
  730. .atomic_post_disable = mtk_dsi_bridge_atomic_post_disable,
  731. .atomic_reset = drm_atomic_helper_bridge_reset,
  732. .mode_valid = mtk_dsi_bridge_mode_valid,
  733. .mode_set = mtk_dsi_bridge_mode_set,
  734. };
  735. void mtk_dsi_ddp_start(struct device *dev)
  736. {
  737. struct mtk_dsi *dsi = dev_get_drvdata(dev);
  738. mtk_dsi_poweron(dsi);
  739. }
  740. void mtk_dsi_ddp_stop(struct device *dev)
  741. {
  742. struct mtk_dsi *dsi = dev_get_drvdata(dev);
  743. mtk_dsi_poweroff(dsi);
  744. }
  745. static int mtk_dsi_encoder_init(struct drm_device *drm, struct mtk_dsi *dsi)
  746. {
  747. int ret;
  748. ret = drm_simple_encoder_init(drm, &dsi->encoder,
  749. DRM_MODE_ENCODER_DSI);
  750. if (ret) {
  751. DRM_ERROR("Failed to encoder init to drm\n");
  752. return ret;
  753. }
  754. ret = mtk_find_possible_crtcs(drm, dsi->host.dev);
  755. if (ret < 0)
  756. goto err_cleanup_encoder;
  757. dsi->encoder.possible_crtcs = ret;
  758. ret = drm_bridge_attach(&dsi->encoder, &dsi->bridge, NULL,
  759. DRM_BRIDGE_ATTACH_NO_CONNECTOR);
  760. if (ret)
  761. goto err_cleanup_encoder;
  762. dsi->connector = drm_bridge_connector_init(drm, &dsi->encoder);
  763. if (IS_ERR(dsi->connector)) {
  764. DRM_ERROR("Unable to create bridge connector\n");
  765. ret = PTR_ERR(dsi->connector);
  766. goto err_cleanup_encoder;
  767. }
  768. drm_connector_attach_encoder(dsi->connector, &dsi->encoder);
  769. return 0;
  770. err_cleanup_encoder:
  771. drm_encoder_cleanup(&dsi->encoder);
  772. return ret;
  773. }
  774. unsigned int mtk_dsi_encoder_index(struct device *dev)
  775. {
  776. struct mtk_dsi *dsi = dev_get_drvdata(dev);
  777. unsigned int encoder_index = drm_encoder_index(&dsi->encoder);
  778. dev_dbg(dev, "encoder index:%d\n", encoder_index);
  779. return encoder_index;
  780. }
  781. static int mtk_dsi_bind(struct device *dev, struct device *master, void *data)
  782. {
  783. int ret;
  784. struct drm_device *drm = data;
  785. struct mtk_dsi *dsi = dev_get_drvdata(dev);
  786. ret = mtk_dsi_encoder_init(drm, dsi);
  787. if (ret)
  788. return ret;
  789. return device_reset_optional(dev);
  790. }
  791. static void mtk_dsi_unbind(struct device *dev, struct device *master,
  792. void *data)
  793. {
  794. struct mtk_dsi *dsi = dev_get_drvdata(dev);
  795. drm_encoder_cleanup(&dsi->encoder);
  796. }
  797. static const struct component_ops mtk_dsi_component_ops = {
  798. .bind = mtk_dsi_bind,
  799. .unbind = mtk_dsi_unbind,
  800. };
  801. static int mtk_dsi_host_attach(struct mipi_dsi_host *host,
  802. struct mipi_dsi_device *device)
  803. {
  804. struct mtk_dsi *dsi = host_to_dsi(host);
  805. struct device *dev = host->dev;
  806. int ret;
  807. dsi->lanes = device->lanes;
  808. dsi->format = device->format;
  809. dsi->mode_flags = device->mode_flags;
  810. dsi->next_bridge = devm_drm_of_get_bridge(dev, dev->of_node, 1, 0);
  811. if (IS_ERR(dsi->next_bridge)) {
  812. ret = PTR_ERR(dsi->next_bridge);
  813. if (ret == -EPROBE_DEFER)
  814. return ret;
  815. /* Old devicetree has only one endpoint */
  816. dsi->next_bridge = devm_drm_of_get_bridge(dev, dev->of_node, 0, 0);
  817. if (IS_ERR(dsi->next_bridge))
  818. return PTR_ERR(dsi->next_bridge);
  819. }
  820. drm_bridge_add(&dsi->bridge);
  821. ret = component_add(host->dev, &mtk_dsi_component_ops);
  822. if (ret) {
  823. DRM_ERROR("failed to add dsi_host component: %d\n", ret);
  824. drm_bridge_remove(&dsi->bridge);
  825. return ret;
  826. }
  827. return 0;
  828. }
  829. static int mtk_dsi_host_detach(struct mipi_dsi_host *host,
  830. struct mipi_dsi_device *device)
  831. {
  832. struct mtk_dsi *dsi = host_to_dsi(host);
  833. component_del(host->dev, &mtk_dsi_component_ops);
  834. drm_bridge_remove(&dsi->bridge);
  835. return 0;
  836. }
  837. static void mtk_dsi_wait_for_idle(struct mtk_dsi *dsi)
  838. {
  839. int ret;
  840. u32 val;
  841. ret = readl_poll_timeout(dsi->regs + DSI_INTSTA, val, !(val & DSI_BUSY),
  842. 4, 2000000);
  843. if (ret) {
  844. DRM_WARN("polling dsi wait not busy timeout!\n");
  845. mtk_dsi_enable(dsi);
  846. mtk_dsi_reset_engine(dsi);
  847. }
  848. }
  849. static u32 mtk_dsi_recv_cnt(u8 type, u8 *read_data)
  850. {
  851. switch (type) {
  852. case MIPI_DSI_RX_GENERIC_SHORT_READ_RESPONSE_1BYTE:
  853. case MIPI_DSI_RX_DCS_SHORT_READ_RESPONSE_1BYTE:
  854. return 1;
  855. case MIPI_DSI_RX_GENERIC_SHORT_READ_RESPONSE_2BYTE:
  856. case MIPI_DSI_RX_DCS_SHORT_READ_RESPONSE_2BYTE:
  857. return 2;
  858. case MIPI_DSI_RX_GENERIC_LONG_READ_RESPONSE:
  859. case MIPI_DSI_RX_DCS_LONG_READ_RESPONSE:
  860. return read_data[1] + read_data[2] * 16;
  861. case MIPI_DSI_RX_ACKNOWLEDGE_AND_ERROR_REPORT:
  862. DRM_INFO("type is 0x02, try again\n");
  863. break;
  864. default:
  865. DRM_INFO("type(0x%x) not recognized\n", type);
  866. break;
  867. }
  868. return 0;
  869. }
  870. static void mtk_dsi_cmdq(struct mtk_dsi *dsi, const struct mipi_dsi_msg *msg)
  871. {
  872. const char *tx_buf = msg->tx_buf;
  873. u8 config, cmdq_size, cmdq_off, type = msg->type;
  874. u32 reg_val, cmdq_mask, i;
  875. u32 reg_cmdq_off = dsi->driver_data->reg_cmdq_off;
  876. if (MTK_DSI_HOST_IS_READ(type))
  877. config = BTA;
  878. else
  879. config = (msg->tx_len > 2) ? LONG_PACKET : SHORT_PACKET;
  880. if (!(msg->flags & MIPI_DSI_MSG_USE_LPM))
  881. config |= HSTX;
  882. if (msg->tx_len > 2) {
  883. cmdq_size = 1 + (msg->tx_len + 3) / 4;
  884. cmdq_off = 4;
  885. cmdq_mask = CONFIG | DATA_ID | DATA_0 | DATA_1;
  886. reg_val = (msg->tx_len << 16) | (type << 8) | config;
  887. } else {
  888. cmdq_size = 1;
  889. cmdq_off = 2;
  890. cmdq_mask = CONFIG | DATA_ID;
  891. reg_val = (type << 8) | config;
  892. }
  893. for (i = 0; i < msg->tx_len; i++)
  894. mtk_dsi_mask(dsi, (reg_cmdq_off + cmdq_off + i) & (~0x3U),
  895. (0xffUL << (((i + cmdq_off) & 3U) * 8U)),
  896. tx_buf[i] << (((i + cmdq_off) & 3U) * 8U));
  897. mtk_dsi_mask(dsi, reg_cmdq_off, cmdq_mask, reg_val);
  898. mtk_dsi_mask(dsi, DSI_CMDQ_SIZE, CMDQ_SIZE, cmdq_size);
  899. if (dsi->driver_data->cmdq_long_packet_ctl) {
  900. /* Disable setting cmdq_size automatically for long packets */
  901. mtk_dsi_mask(dsi, DSI_CMDQ_SIZE, CMDQ_SIZE_SEL, CMDQ_SIZE_SEL);
  902. }
  903. }
  904. static ssize_t mtk_dsi_host_send_cmd(struct mtk_dsi *dsi,
  905. const struct mipi_dsi_msg *msg, u8 flag)
  906. {
  907. mtk_dsi_wait_for_idle(dsi);
  908. mtk_dsi_irq_data_clear(dsi, flag);
  909. mtk_dsi_cmdq(dsi, msg);
  910. mtk_dsi_start(dsi);
  911. if (!mtk_dsi_wait_for_irq_done(dsi, flag, 2000))
  912. return -ETIME;
  913. else
  914. return 0;
  915. }
  916. static ssize_t mtk_dsi_host_transfer(struct mipi_dsi_host *host,
  917. const struct mipi_dsi_msg *msg)
  918. {
  919. struct mtk_dsi *dsi = host_to_dsi(host);
  920. ssize_t recv_cnt;
  921. u8 read_data[16];
  922. void *src_addr;
  923. u8 irq_flag = CMD_DONE_INT_FLAG;
  924. u32 dsi_mode;
  925. int ret, i;
  926. dsi_mode = readl(dsi->regs + DSI_MODE_CTRL);
  927. if (dsi_mode & MODE) {
  928. mtk_dsi_stop(dsi);
  929. ret = mtk_dsi_switch_to_cmd_mode(dsi, VM_DONE_INT_FLAG, 500);
  930. if (ret)
  931. goto restore_dsi_mode;
  932. }
  933. if (MTK_DSI_HOST_IS_READ(msg->type))
  934. irq_flag |= LPRX_RD_RDY_INT_FLAG;
  935. mtk_dsi_lane_ready(dsi);
  936. ret = mtk_dsi_host_send_cmd(dsi, msg, irq_flag);
  937. if (ret)
  938. goto restore_dsi_mode;
  939. if (!MTK_DSI_HOST_IS_READ(msg->type)) {
  940. recv_cnt = 0;
  941. goto restore_dsi_mode;
  942. }
  943. if (!msg->rx_buf) {
  944. DRM_ERROR("dsi receive buffer size may be NULL\n");
  945. ret = -EINVAL;
  946. goto restore_dsi_mode;
  947. }
  948. for (i = 0; i < 16; i++)
  949. *(read_data + i) = readb(dsi->regs + DSI_RX_DATA0 + i);
  950. recv_cnt = mtk_dsi_recv_cnt(read_data[0], read_data);
  951. if (recv_cnt > 2)
  952. src_addr = &read_data[4];
  953. else
  954. src_addr = &read_data[1];
  955. if (recv_cnt > 10)
  956. recv_cnt = 10;
  957. if (recv_cnt > msg->rx_len)
  958. recv_cnt = msg->rx_len;
  959. if (recv_cnt)
  960. memcpy(msg->rx_buf, src_addr, recv_cnt);
  961. DRM_INFO("dsi get %zd byte data from the panel address(0x%x)\n",
  962. recv_cnt, *((u8 *)(msg->tx_buf)));
  963. restore_dsi_mode:
  964. if (dsi_mode & MODE) {
  965. mtk_dsi_set_mode(dsi);
  966. mtk_dsi_start(dsi);
  967. }
  968. return ret < 0 ? ret : recv_cnt;
  969. }
  970. static const struct mipi_dsi_host_ops mtk_dsi_ops = {
  971. .attach = mtk_dsi_host_attach,
  972. .detach = mtk_dsi_host_detach,
  973. .transfer = mtk_dsi_host_transfer,
  974. };
  975. static int mtk_dsi_probe(struct platform_device *pdev)
  976. {
  977. struct mtk_dsi *dsi;
  978. struct device *dev = &pdev->dev;
  979. int irq_num;
  980. int ret;
  981. dsi = devm_drm_bridge_alloc(dev, struct mtk_dsi, bridge,
  982. &mtk_dsi_bridge_funcs);
  983. if (IS_ERR(dsi))
  984. return PTR_ERR(dsi);
  985. dsi->driver_data = of_device_get_match_data(dev);
  986. dsi->engine_clk = devm_clk_get(dev, "engine");
  987. if (IS_ERR(dsi->engine_clk))
  988. return dev_err_probe(dev, PTR_ERR(dsi->engine_clk),
  989. "Failed to get engine clock\n");
  990. dsi->digital_clk = devm_clk_get(dev, "digital");
  991. if (IS_ERR(dsi->digital_clk))
  992. return dev_err_probe(dev, PTR_ERR(dsi->digital_clk),
  993. "Failed to get digital clock\n");
  994. dsi->hs_clk = devm_clk_get(dev, "hs");
  995. if (IS_ERR(dsi->hs_clk))
  996. return dev_err_probe(dev, PTR_ERR(dsi->hs_clk), "Failed to get hs clock\n");
  997. dsi->regs = devm_platform_ioremap_resource(pdev, 0);
  998. if (IS_ERR(dsi->regs))
  999. return dev_err_probe(dev, PTR_ERR(dsi->regs), "Failed to ioremap memory\n");
  1000. dsi->phy = devm_phy_get(dev, "dphy");
  1001. if (IS_ERR(dsi->phy))
  1002. return dev_err_probe(dev, PTR_ERR(dsi->phy), "Failed to get MIPI-DPHY\n");
  1003. irq_num = platform_get_irq(pdev, 0);
  1004. if (irq_num < 0)
  1005. return irq_num;
  1006. dsi->host.ops = &mtk_dsi_ops;
  1007. dsi->host.dev = dev;
  1008. init_waitqueue_head(&dsi->irq_wait_queue);
  1009. platform_set_drvdata(pdev, dsi);
  1010. ret = mipi_dsi_host_register(&dsi->host);
  1011. if (ret < 0)
  1012. return dev_err_probe(dev, ret, "Failed to register DSI host\n");
  1013. ret = devm_request_irq(&pdev->dev, irq_num, mtk_dsi_irq,
  1014. IRQF_TRIGGER_NONE, dev_name(&pdev->dev), dsi);
  1015. if (ret) {
  1016. mipi_dsi_host_unregister(&dsi->host);
  1017. return dev_err_probe(&pdev->dev, ret, "Failed to request DSI irq\n");
  1018. }
  1019. dsi->bridge.of_node = dev->of_node;
  1020. dsi->bridge.type = DRM_MODE_CONNECTOR_DSI;
  1021. return 0;
  1022. }
  1023. static void mtk_dsi_remove(struct platform_device *pdev)
  1024. {
  1025. struct mtk_dsi *dsi = platform_get_drvdata(pdev);
  1026. mtk_output_dsi_disable(dsi);
  1027. mipi_dsi_host_unregister(&dsi->host);
  1028. }
  1029. static const struct mtk_dsi_driver_data mt8173_dsi_driver_data = {
  1030. .reg_cmdq_off = 0x200,
  1031. .reg_vm_cmd_off = 0x130,
  1032. .reg_shadow_dbg_off = 0x190
  1033. };
  1034. static const struct mtk_dsi_driver_data mt2701_dsi_driver_data = {
  1035. .reg_cmdq_off = 0x180,
  1036. .reg_vm_cmd_off = 0x130,
  1037. .reg_shadow_dbg_off = 0x190
  1038. };
  1039. static const struct mtk_dsi_driver_data mt8183_dsi_driver_data = {
  1040. .reg_cmdq_off = 0x200,
  1041. .reg_vm_cmd_off = 0x130,
  1042. .reg_shadow_dbg_off = 0x190,
  1043. .has_shadow_ctl = true,
  1044. .has_size_ctl = true,
  1045. };
  1046. static const struct mtk_dsi_driver_data mt8186_dsi_driver_data = {
  1047. .reg_cmdq_off = 0xd00,
  1048. .reg_vm_cmd_off = 0x200,
  1049. .reg_shadow_dbg_off = 0xc00,
  1050. .has_shadow_ctl = true,
  1051. .has_size_ctl = true,
  1052. };
  1053. static const struct mtk_dsi_driver_data mt8188_dsi_driver_data = {
  1054. .reg_cmdq_off = 0xd00,
  1055. .reg_vm_cmd_off = 0x200,
  1056. .reg_shadow_dbg_off = 0xc00,
  1057. .has_shadow_ctl = true,
  1058. .has_size_ctl = true,
  1059. .cmdq_long_packet_ctl = true,
  1060. .support_per_frame_lp = true,
  1061. };
  1062. static const struct of_device_id mtk_dsi_of_match[] = {
  1063. { .compatible = "mediatek,mt2701-dsi", .data = &mt2701_dsi_driver_data },
  1064. { .compatible = "mediatek,mt8173-dsi", .data = &mt8173_dsi_driver_data },
  1065. { .compatible = "mediatek,mt8183-dsi", .data = &mt8183_dsi_driver_data },
  1066. { .compatible = "mediatek,mt8186-dsi", .data = &mt8186_dsi_driver_data },
  1067. { .compatible = "mediatek,mt8188-dsi", .data = &mt8188_dsi_driver_data },
  1068. { /* sentinel */ }
  1069. };
  1070. MODULE_DEVICE_TABLE(of, mtk_dsi_of_match);
  1071. struct platform_driver mtk_dsi_driver = {
  1072. .probe = mtk_dsi_probe,
  1073. .remove = mtk_dsi_remove,
  1074. .driver = {
  1075. .name = "mtk-dsi",
  1076. .of_match_table = mtk_dsi_of_match,
  1077. },
  1078. };