parade-ps8640.c 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2016 MediaTek Inc.
  4. */
  5. #include <linux/delay.h>
  6. #include <linux/err.h>
  7. #include <linux/gpio/consumer.h>
  8. #include <linux/i2c.h>
  9. #include <linux/module.h>
  10. #include <linux/of_graph.h>
  11. #include <linux/pm_runtime.h>
  12. #include <linux/regmap.h>
  13. #include <linux/regulator/consumer.h>
  14. #include <drm/display/drm_dp_aux_bus.h>
  15. #include <drm/display/drm_dp_helper.h>
  16. #include <drm/drm_atomic_state_helper.h>
  17. #include <drm/drm_bridge.h>
  18. #include <drm/drm_edid.h>
  19. #include <drm/drm_mipi_dsi.h>
  20. #include <drm/drm_of.h>
  21. #include <drm/drm_print.h>
  22. #define PAGE0_AUXCH_CFG3 0x76
  23. #define AUXCH_CFG3_RESET 0xff
  24. #define PAGE0_SWAUX_ADDR_7_0 0x7d
  25. #define PAGE0_SWAUX_ADDR_15_8 0x7e
  26. #define PAGE0_SWAUX_ADDR_23_16 0x7f
  27. #define SWAUX_ADDR_MASK GENMASK(19, 0)
  28. #define PAGE0_SWAUX_LENGTH 0x80
  29. #define SWAUX_LENGTH_MASK GENMASK(3, 0)
  30. #define SWAUX_NO_PAYLOAD BIT(7)
  31. #define PAGE0_SWAUX_WDATA 0x81
  32. #define PAGE0_SWAUX_RDATA 0x82
  33. #define PAGE0_SWAUX_CTRL 0x83
  34. #define SWAUX_SEND BIT(0)
  35. #define PAGE0_SWAUX_STATUS 0x84
  36. #define SWAUX_M_MASK GENMASK(4, 0)
  37. #define SWAUX_STATUS_MASK GENMASK(7, 5)
  38. #define SWAUX_STATUS_NACK (0x1 << 5)
  39. #define SWAUX_STATUS_DEFER (0x2 << 5)
  40. #define SWAUX_STATUS_ACKM (0x3 << 5)
  41. #define SWAUX_STATUS_INVALID (0x4 << 5)
  42. #define SWAUX_STATUS_I2C_NACK (0x5 << 5)
  43. #define SWAUX_STATUS_I2C_DEFER (0x6 << 5)
  44. #define SWAUX_STATUS_TIMEOUT (0x7 << 5)
  45. #define PAGE2_GPIO_H 0xa7
  46. #define PS_GPIO9 BIT(1)
  47. #define PAGE2_I2C_BYPASS 0xea
  48. #define I2C_BYPASS_EN 0xd0
  49. #define PAGE2_MCS_EN 0xf3
  50. #define MCS_EN BIT(0)
  51. #define PAGE3_SET_ADD 0xfe
  52. #define VDO_CTL_ADD 0x13
  53. #define VDO_DIS 0x18
  54. #define VDO_EN 0x1c
  55. #define NUM_MIPI_LANES 4
  56. #define COMMON_PS8640_REGMAP_CONFIG \
  57. .reg_bits = 8, \
  58. .val_bits = 8, \
  59. .cache_type = REGCACHE_NONE
  60. /*
  61. * PS8640 uses multiple addresses:
  62. * page[0]: for DP control
  63. * page[1]: for VIDEO Bridge
  64. * page[2]: for control top
  65. * page[3]: for DSI Link Control1
  66. * page[4]: for MIPI Phy
  67. * page[5]: for VPLL
  68. * page[6]: for DSI Link Control2
  69. * page[7]: for SPI ROM mapping
  70. */
  71. enum page_addr_offset {
  72. PAGE0_DP_CNTL = 0,
  73. PAGE1_VDO_BDG,
  74. PAGE2_TOP_CNTL,
  75. PAGE3_DSI_CNTL1,
  76. PAGE4_MIPI_PHY,
  77. PAGE5_VPLL,
  78. PAGE6_DSI_CNTL2,
  79. PAGE7_SPI_CNTL,
  80. MAX_DEVS
  81. };
  82. enum ps8640_vdo_control {
  83. DISABLE = VDO_DIS,
  84. ENABLE = VDO_EN,
  85. };
  86. struct ps8640 {
  87. struct drm_bridge bridge;
  88. struct drm_bridge *panel_bridge;
  89. struct drm_dp_aux aux;
  90. struct mipi_dsi_device *dsi;
  91. struct i2c_client *page[MAX_DEVS];
  92. struct regmap *regmap[MAX_DEVS];
  93. struct regulator_bulk_data supplies[2];
  94. struct gpio_desc *gpio_reset;
  95. struct gpio_desc *gpio_powerdown;
  96. struct device_link *link;
  97. bool pre_enabled;
  98. bool need_post_hpd_delay;
  99. struct mutex aux_lock;
  100. };
  101. static const struct regmap_config ps8640_regmap_config[] = {
  102. [PAGE0_DP_CNTL] = {
  103. COMMON_PS8640_REGMAP_CONFIG,
  104. .max_register = 0xbf,
  105. },
  106. [PAGE1_VDO_BDG] = {
  107. COMMON_PS8640_REGMAP_CONFIG,
  108. .max_register = 0xff,
  109. },
  110. [PAGE2_TOP_CNTL] = {
  111. COMMON_PS8640_REGMAP_CONFIG,
  112. .max_register = 0xff,
  113. },
  114. [PAGE3_DSI_CNTL1] = {
  115. COMMON_PS8640_REGMAP_CONFIG,
  116. .max_register = 0xff,
  117. },
  118. [PAGE4_MIPI_PHY] = {
  119. COMMON_PS8640_REGMAP_CONFIG,
  120. .max_register = 0xff,
  121. },
  122. [PAGE5_VPLL] = {
  123. COMMON_PS8640_REGMAP_CONFIG,
  124. .max_register = 0x7f,
  125. },
  126. [PAGE6_DSI_CNTL2] = {
  127. COMMON_PS8640_REGMAP_CONFIG,
  128. .max_register = 0xff,
  129. },
  130. [PAGE7_SPI_CNTL] = {
  131. COMMON_PS8640_REGMAP_CONFIG,
  132. .max_register = 0xff,
  133. },
  134. };
  135. static inline struct ps8640 *bridge_to_ps8640(struct drm_bridge *e)
  136. {
  137. return container_of(e, struct ps8640, bridge);
  138. }
  139. static inline struct ps8640 *aux_to_ps8640(struct drm_dp_aux *aux)
  140. {
  141. return container_of(aux, struct ps8640, aux);
  142. }
  143. static int _ps8640_wait_hpd_asserted(struct ps8640 *ps_bridge, unsigned long wait_us)
  144. {
  145. struct regmap *map = ps_bridge->regmap[PAGE2_TOP_CNTL];
  146. int status;
  147. int ret;
  148. /*
  149. * Apparently something about the firmware in the chip signals that
  150. * HPD goes high by reporting GPIO9 as high (even though HPD isn't
  151. * actually connected to GPIO9).
  152. */
  153. ret = regmap_read_poll_timeout(map, PAGE2_GPIO_H, status,
  154. status & PS_GPIO9, 20000, wait_us);
  155. /*
  156. * The first time we see HPD go high after a reset we delay an extra
  157. * 50 ms. The best guess is that the MCU is doing "stuff" during this
  158. * time (maybe talking to the panel) and we don't want to interrupt it.
  159. *
  160. * No locking is done around "need_post_hpd_delay". If we're here we
  161. * know we're holding a PM Runtime reference and the only other place
  162. * that touches this is PM Runtime resume.
  163. */
  164. if (!ret && ps_bridge->need_post_hpd_delay) {
  165. ps_bridge->need_post_hpd_delay = false;
  166. msleep(50);
  167. }
  168. return ret;
  169. }
  170. static int ps8640_wait_hpd_asserted(struct drm_dp_aux *aux, unsigned long wait_us)
  171. {
  172. struct ps8640 *ps_bridge = aux_to_ps8640(aux);
  173. struct device *dev = &ps_bridge->page[PAGE0_DP_CNTL]->dev;
  174. int ret;
  175. /*
  176. * Note that this function is called by code that has already powered
  177. * the panel. We have to power ourselves up but we don't need to worry
  178. * about powering the panel.
  179. */
  180. pm_runtime_get_sync(dev);
  181. ret = _ps8640_wait_hpd_asserted(ps_bridge, wait_us);
  182. pm_runtime_mark_last_busy(dev);
  183. pm_runtime_put_autosuspend(dev);
  184. return ret;
  185. }
  186. static ssize_t ps8640_aux_transfer_msg(struct drm_dp_aux *aux,
  187. struct drm_dp_aux_msg *msg)
  188. {
  189. struct ps8640 *ps_bridge = aux_to_ps8640(aux);
  190. struct regmap *map = ps_bridge->regmap[PAGE0_DP_CNTL];
  191. struct device *dev = &ps_bridge->page[PAGE0_DP_CNTL]->dev;
  192. size_t len = msg->size;
  193. unsigned int data;
  194. unsigned int base;
  195. int ret;
  196. u8 request = msg->request &
  197. ~(DP_AUX_I2C_MOT | DP_AUX_I2C_WRITE_STATUS_UPDATE);
  198. u8 *buf = msg->buffer;
  199. u8 addr_len[PAGE0_SWAUX_LENGTH + 1 - PAGE0_SWAUX_ADDR_7_0];
  200. u8 i;
  201. bool is_native_aux = false;
  202. if (len > DP_AUX_MAX_PAYLOAD_BYTES)
  203. return -EINVAL;
  204. if (msg->address & ~SWAUX_ADDR_MASK)
  205. return -EINVAL;
  206. switch (request) {
  207. case DP_AUX_NATIVE_WRITE:
  208. case DP_AUX_NATIVE_READ:
  209. is_native_aux = true;
  210. fallthrough;
  211. case DP_AUX_I2C_WRITE:
  212. case DP_AUX_I2C_READ:
  213. break;
  214. default:
  215. return -EINVAL;
  216. }
  217. ret = regmap_write(map, PAGE0_AUXCH_CFG3, AUXCH_CFG3_RESET);
  218. if (ret) {
  219. DRM_DEV_ERROR(dev, "failed to write PAGE0_AUXCH_CFG3: %d\n",
  220. ret);
  221. return ret;
  222. }
  223. /* Assume it's good */
  224. msg->reply = 0;
  225. base = PAGE0_SWAUX_ADDR_7_0;
  226. addr_len[PAGE0_SWAUX_ADDR_7_0 - base] = msg->address;
  227. addr_len[PAGE0_SWAUX_ADDR_15_8 - base] = msg->address >> 8;
  228. addr_len[PAGE0_SWAUX_ADDR_23_16 - base] = (msg->address >> 16) |
  229. (msg->request << 4);
  230. addr_len[PAGE0_SWAUX_LENGTH - base] = (len == 0) ? SWAUX_NO_PAYLOAD :
  231. ((len - 1) & SWAUX_LENGTH_MASK);
  232. regmap_bulk_write(map, PAGE0_SWAUX_ADDR_7_0, addr_len,
  233. ARRAY_SIZE(addr_len));
  234. if (len && (request == DP_AUX_NATIVE_WRITE ||
  235. request == DP_AUX_I2C_WRITE)) {
  236. /* Write to the internal FIFO buffer */
  237. for (i = 0; i < len; i++) {
  238. ret = regmap_write(map, PAGE0_SWAUX_WDATA, buf[i]);
  239. if (ret) {
  240. DRM_DEV_ERROR(dev,
  241. "failed to write WDATA: %d\n",
  242. ret);
  243. return ret;
  244. }
  245. }
  246. }
  247. regmap_write(map, PAGE0_SWAUX_CTRL, SWAUX_SEND);
  248. /* Zero delay loop because i2c transactions are slow already */
  249. regmap_read_poll_timeout(map, PAGE0_SWAUX_CTRL, data,
  250. !(data & SWAUX_SEND), 0, 50 * 1000);
  251. regmap_read(map, PAGE0_SWAUX_STATUS, &data);
  252. if (ret) {
  253. DRM_DEV_ERROR(dev, "failed to read PAGE0_SWAUX_STATUS: %d\n",
  254. ret);
  255. return ret;
  256. }
  257. switch (data & SWAUX_STATUS_MASK) {
  258. case SWAUX_STATUS_NACK:
  259. case SWAUX_STATUS_I2C_NACK:
  260. /*
  261. * The programming guide is not clear about whether a I2C NACK
  262. * would trigger SWAUX_STATUS_NACK or SWAUX_STATUS_I2C_NACK. So
  263. * we handle both cases together.
  264. */
  265. if (is_native_aux)
  266. msg->reply |= DP_AUX_NATIVE_REPLY_NACK;
  267. else
  268. msg->reply |= DP_AUX_I2C_REPLY_NACK;
  269. fallthrough;
  270. case SWAUX_STATUS_ACKM:
  271. len = data & SWAUX_M_MASK;
  272. break;
  273. case SWAUX_STATUS_DEFER:
  274. case SWAUX_STATUS_I2C_DEFER:
  275. if (is_native_aux)
  276. msg->reply |= DP_AUX_NATIVE_REPLY_DEFER;
  277. else
  278. msg->reply |= DP_AUX_I2C_REPLY_DEFER;
  279. len = data & SWAUX_M_MASK;
  280. break;
  281. case SWAUX_STATUS_INVALID:
  282. return -EOPNOTSUPP;
  283. case SWAUX_STATUS_TIMEOUT:
  284. return -ETIMEDOUT;
  285. }
  286. if (len && (request == DP_AUX_NATIVE_READ ||
  287. request == DP_AUX_I2C_READ)) {
  288. /* Read from the internal FIFO buffer */
  289. for (i = 0; i < len; i++) {
  290. ret = regmap_read(map, PAGE0_SWAUX_RDATA, &data);
  291. if (ret) {
  292. DRM_DEV_ERROR(dev,
  293. "failed to read RDATA: %d\n",
  294. ret);
  295. return ret;
  296. }
  297. if (i < msg->size)
  298. buf[i] = data;
  299. }
  300. }
  301. return min(len, msg->size);
  302. }
  303. static ssize_t ps8640_aux_transfer(struct drm_dp_aux *aux,
  304. struct drm_dp_aux_msg *msg)
  305. {
  306. struct ps8640 *ps_bridge = aux_to_ps8640(aux);
  307. struct device *dev = &ps_bridge->page[PAGE0_DP_CNTL]->dev;
  308. int ret;
  309. mutex_lock(&ps_bridge->aux_lock);
  310. pm_runtime_get_sync(dev);
  311. ret = _ps8640_wait_hpd_asserted(ps_bridge, 200 * 1000);
  312. if (ret) {
  313. pm_runtime_put_sync_suspend(dev);
  314. goto exit;
  315. }
  316. ret = ps8640_aux_transfer_msg(aux, msg);
  317. pm_runtime_mark_last_busy(dev);
  318. pm_runtime_put_autosuspend(dev);
  319. exit:
  320. mutex_unlock(&ps_bridge->aux_lock);
  321. return ret;
  322. }
  323. static void ps8640_bridge_vdo_control(struct ps8640 *ps_bridge,
  324. const enum ps8640_vdo_control ctrl)
  325. {
  326. struct regmap *map = ps_bridge->regmap[PAGE3_DSI_CNTL1];
  327. struct device *dev = &ps_bridge->page[PAGE3_DSI_CNTL1]->dev;
  328. u8 vdo_ctrl_buf[] = { VDO_CTL_ADD, ctrl };
  329. int ret;
  330. ret = regmap_bulk_write(map, PAGE3_SET_ADD,
  331. vdo_ctrl_buf, sizeof(vdo_ctrl_buf));
  332. if (ret < 0)
  333. dev_err(dev, "failed to %sable VDO: %d\n",
  334. ctrl == ENABLE ? "en" : "dis", ret);
  335. }
  336. static int __maybe_unused ps8640_resume(struct device *dev)
  337. {
  338. struct ps8640 *ps_bridge = dev_get_drvdata(dev);
  339. int ret;
  340. ret = regulator_bulk_enable(ARRAY_SIZE(ps_bridge->supplies),
  341. ps_bridge->supplies);
  342. if (ret < 0) {
  343. dev_err(dev, "cannot enable regulators %d\n", ret);
  344. return ret;
  345. }
  346. gpiod_set_value(ps_bridge->gpio_powerdown, 0);
  347. gpiod_set_value(ps_bridge->gpio_reset, 1);
  348. usleep_range(2000, 2500);
  349. gpiod_set_value(ps_bridge->gpio_reset, 0);
  350. /* Double reset for T4 and T5 */
  351. msleep(50);
  352. gpiod_set_value(ps_bridge->gpio_reset, 1);
  353. msleep(50);
  354. gpiod_set_value(ps_bridge->gpio_reset, 0);
  355. /* We just reset things, so we need a delay after the first HPD */
  356. ps_bridge->need_post_hpd_delay = true;
  357. /*
  358. * Mystery 200 ms delay for the "MCU to be ready". It's unclear if
  359. * this is truly necessary since the MCU will already signal that
  360. * things are "good to go" by signaling HPD on "gpio 9". See
  361. * _ps8640_wait_hpd_asserted(). For now we'll keep this mystery delay
  362. * just in case.
  363. */
  364. msleep(200);
  365. return 0;
  366. }
  367. static int __maybe_unused ps8640_suspend(struct device *dev)
  368. {
  369. struct ps8640 *ps_bridge = dev_get_drvdata(dev);
  370. int ret;
  371. gpiod_set_value(ps_bridge->gpio_reset, 1);
  372. gpiod_set_value(ps_bridge->gpio_powerdown, 1);
  373. ret = regulator_bulk_disable(ARRAY_SIZE(ps_bridge->supplies),
  374. ps_bridge->supplies);
  375. if (ret < 0)
  376. dev_err(dev, "cannot disable regulators %d\n", ret);
  377. return ret;
  378. }
  379. static const struct dev_pm_ops ps8640_pm_ops = {
  380. SET_RUNTIME_PM_OPS(ps8640_suspend, ps8640_resume, NULL)
  381. SET_SYSTEM_SLEEP_PM_OPS(pm_runtime_force_suspend,
  382. pm_runtime_force_resume)
  383. };
  384. static void ps8640_atomic_pre_enable(struct drm_bridge *bridge,
  385. struct drm_atomic_state *state)
  386. {
  387. struct ps8640 *ps_bridge = bridge_to_ps8640(bridge);
  388. struct regmap *map = ps_bridge->regmap[PAGE2_TOP_CNTL];
  389. struct device *dev = &ps_bridge->page[PAGE0_DP_CNTL]->dev;
  390. int ret;
  391. pm_runtime_get_sync(dev);
  392. ret = _ps8640_wait_hpd_asserted(ps_bridge, 200 * 1000);
  393. if (ret < 0)
  394. dev_warn(dev, "HPD didn't go high: %d\n", ret);
  395. /*
  396. * The Manufacturer Command Set (MCS) is a device dependent interface
  397. * intended for factory programming of the display module default
  398. * parameters. Once the display module is configured, the MCS shall be
  399. * disabled by the manufacturer. Once disabled, all MCS commands are
  400. * ignored by the display interface.
  401. */
  402. ret = regmap_update_bits(map, PAGE2_MCS_EN, MCS_EN, 0);
  403. if (ret < 0)
  404. dev_warn(dev, "failed write PAGE2_MCS_EN: %d\n", ret);
  405. /* Switch access edp panel's edid through i2c */
  406. ret = regmap_write(map, PAGE2_I2C_BYPASS, I2C_BYPASS_EN);
  407. if (ret < 0)
  408. dev_warn(dev, "failed write PAGE2_MCS_EN: %d\n", ret);
  409. ps8640_bridge_vdo_control(ps_bridge, ENABLE);
  410. ps_bridge->pre_enabled = true;
  411. }
  412. static void ps8640_atomic_post_disable(struct drm_bridge *bridge,
  413. struct drm_atomic_state *state)
  414. {
  415. struct ps8640 *ps_bridge = bridge_to_ps8640(bridge);
  416. ps_bridge->pre_enabled = false;
  417. ps8640_bridge_vdo_control(ps_bridge, DISABLE);
  418. /*
  419. * The bridge seems to expect everything to be power cycled at the
  420. * disable process, so grab a lock here to make sure
  421. * ps8640_aux_transfer() is not holding a runtime PM reference and
  422. * preventing the bridge from suspend.
  423. */
  424. mutex_lock(&ps_bridge->aux_lock);
  425. pm_runtime_put_sync_suspend(&ps_bridge->page[PAGE0_DP_CNTL]->dev);
  426. mutex_unlock(&ps_bridge->aux_lock);
  427. }
  428. static int ps8640_bridge_attach(struct drm_bridge *bridge,
  429. struct drm_encoder *encoder,
  430. enum drm_bridge_attach_flags flags)
  431. {
  432. struct ps8640 *ps_bridge = bridge_to_ps8640(bridge);
  433. struct device *dev = &ps_bridge->page[0]->dev;
  434. int ret;
  435. if (!(flags & DRM_BRIDGE_ATTACH_NO_CONNECTOR))
  436. return -EINVAL;
  437. ps_bridge->aux.drm_dev = bridge->dev;
  438. ret = drm_dp_aux_register(&ps_bridge->aux);
  439. if (ret) {
  440. dev_err(dev, "failed to register DP AUX channel: %d\n", ret);
  441. return ret;
  442. }
  443. ps_bridge->link = device_link_add(bridge->dev->dev, dev, DL_FLAG_STATELESS);
  444. if (!ps_bridge->link) {
  445. dev_err(dev, "failed to create device link");
  446. ret = -EINVAL;
  447. goto err_devlink;
  448. }
  449. /* Attach the panel-bridge to the dsi bridge */
  450. ret = drm_bridge_attach(encoder, ps_bridge->panel_bridge,
  451. &ps_bridge->bridge, flags);
  452. if (ret)
  453. goto err_bridge_attach;
  454. return 0;
  455. err_bridge_attach:
  456. device_link_del(ps_bridge->link);
  457. err_devlink:
  458. drm_dp_aux_unregister(&ps_bridge->aux);
  459. return ret;
  460. }
  461. static void ps8640_bridge_detach(struct drm_bridge *bridge)
  462. {
  463. struct ps8640 *ps_bridge = bridge_to_ps8640(bridge);
  464. drm_dp_aux_unregister(&ps_bridge->aux);
  465. if (ps_bridge->link)
  466. device_link_del(ps_bridge->link);
  467. }
  468. static void ps8640_runtime_disable(void *data)
  469. {
  470. pm_runtime_dont_use_autosuspend(data);
  471. pm_runtime_disable(data);
  472. }
  473. static const struct drm_bridge_funcs ps8640_bridge_funcs = {
  474. .attach = ps8640_bridge_attach,
  475. .detach = ps8640_bridge_detach,
  476. .atomic_post_disable = ps8640_atomic_post_disable,
  477. .atomic_pre_enable = ps8640_atomic_pre_enable,
  478. .atomic_duplicate_state = drm_atomic_helper_bridge_duplicate_state,
  479. .atomic_destroy_state = drm_atomic_helper_bridge_destroy_state,
  480. .atomic_reset = drm_atomic_helper_bridge_reset,
  481. };
  482. static int ps8640_bridge_get_dsi_resources(struct device *dev, struct ps8640 *ps_bridge)
  483. {
  484. struct device_node *in_ep, *dsi_node;
  485. struct mipi_dsi_device *dsi;
  486. struct mipi_dsi_host *host;
  487. const struct mipi_dsi_device_info info = { .type = "ps8640",
  488. .channel = 0,
  489. .node = NULL,
  490. };
  491. /* port@0 is ps8640 dsi input port */
  492. in_ep = of_graph_get_endpoint_by_regs(dev->of_node, 0, -1);
  493. if (!in_ep)
  494. return -ENODEV;
  495. dsi_node = of_graph_get_remote_port_parent(in_ep);
  496. of_node_put(in_ep);
  497. if (!dsi_node)
  498. return -ENODEV;
  499. host = of_find_mipi_dsi_host_by_node(dsi_node);
  500. of_node_put(dsi_node);
  501. if (!host)
  502. return -EPROBE_DEFER;
  503. dsi = devm_mipi_dsi_device_register_full(dev, host, &info);
  504. if (IS_ERR(dsi)) {
  505. dev_err(dev, "failed to create dsi device\n");
  506. return PTR_ERR(dsi);
  507. }
  508. ps_bridge->dsi = dsi;
  509. dsi->host = host;
  510. dsi->mode_flags = MIPI_DSI_MODE_VIDEO |
  511. MIPI_DSI_MODE_VIDEO_SYNC_PULSE;
  512. dsi->format = MIPI_DSI_FMT_RGB888;
  513. dsi->lanes = NUM_MIPI_LANES;
  514. return 0;
  515. }
  516. static int ps8640_bridge_link_panel(struct drm_dp_aux *aux)
  517. {
  518. struct ps8640 *ps_bridge = aux_to_ps8640(aux);
  519. struct device *dev = aux->dev;
  520. struct device_node *np = dev->of_node;
  521. int ret;
  522. /*
  523. * NOTE about returning -EPROBE_DEFER from this function: if we
  524. * return an error (most relevant to -EPROBE_DEFER) it will only
  525. * be passed out to ps8640_probe() if it called this directly (AKA the
  526. * panel isn't under the "aux-bus" node). That should be fine because
  527. * if the panel is under "aux-bus" it's guaranteed to have probed by
  528. * the time this function has been called.
  529. */
  530. /* port@1 is ps8640 output port */
  531. ps_bridge->panel_bridge = devm_drm_of_get_bridge(dev, np, 1, 0);
  532. if (IS_ERR(ps_bridge->panel_bridge))
  533. return PTR_ERR(ps_bridge->panel_bridge);
  534. ret = devm_drm_bridge_add(dev, &ps_bridge->bridge);
  535. if (ret)
  536. return ret;
  537. return devm_mipi_dsi_attach(dev, ps_bridge->dsi);
  538. }
  539. static int ps8640_probe(struct i2c_client *client)
  540. {
  541. struct device *dev = &client->dev;
  542. struct ps8640 *ps_bridge;
  543. int ret;
  544. u32 i;
  545. ps_bridge = devm_drm_bridge_alloc(dev, struct ps8640, bridge,
  546. &ps8640_bridge_funcs);
  547. if (IS_ERR(ps_bridge))
  548. return PTR_ERR(ps_bridge);
  549. mutex_init(&ps_bridge->aux_lock);
  550. ps_bridge->supplies[0].supply = "vdd12";
  551. ps_bridge->supplies[1].supply = "vdd33";
  552. ret = devm_regulator_bulk_get(dev, ARRAY_SIZE(ps_bridge->supplies),
  553. ps_bridge->supplies);
  554. if (ret)
  555. return ret;
  556. ps_bridge->gpio_powerdown = devm_gpiod_get(&client->dev, "powerdown",
  557. GPIOD_OUT_HIGH);
  558. if (IS_ERR(ps_bridge->gpio_powerdown))
  559. return PTR_ERR(ps_bridge->gpio_powerdown);
  560. /*
  561. * Assert the reset to avoid the bridge being initialized prematurely
  562. */
  563. ps_bridge->gpio_reset = devm_gpiod_get(&client->dev, "reset",
  564. GPIOD_OUT_HIGH);
  565. if (IS_ERR(ps_bridge->gpio_reset))
  566. return PTR_ERR(ps_bridge->gpio_reset);
  567. ps_bridge->bridge.of_node = dev->of_node;
  568. ps_bridge->bridge.type = DRM_MODE_CONNECTOR_eDP;
  569. /*
  570. * Get MIPI DSI resources early. These can return -EPROBE_DEFER so
  571. * we want to get them out of the way sooner.
  572. */
  573. ret = ps8640_bridge_get_dsi_resources(&client->dev, ps_bridge);
  574. if (ret)
  575. return ret;
  576. ps_bridge->page[PAGE0_DP_CNTL] = client;
  577. ps_bridge->regmap[PAGE0_DP_CNTL] = devm_regmap_init_i2c(client, ps8640_regmap_config);
  578. if (IS_ERR(ps_bridge->regmap[PAGE0_DP_CNTL]))
  579. return PTR_ERR(ps_bridge->regmap[PAGE0_DP_CNTL]);
  580. for (i = 1; i < ARRAY_SIZE(ps_bridge->page); i++) {
  581. ps_bridge->page[i] = devm_i2c_new_dummy_device(&client->dev,
  582. client->adapter,
  583. client->addr + i);
  584. if (IS_ERR(ps_bridge->page[i]))
  585. return PTR_ERR(ps_bridge->page[i]);
  586. ps_bridge->regmap[i] = devm_regmap_init_i2c(ps_bridge->page[i],
  587. ps8640_regmap_config + i);
  588. if (IS_ERR(ps_bridge->regmap[i]))
  589. return PTR_ERR(ps_bridge->regmap[i]);
  590. }
  591. i2c_set_clientdata(client, ps_bridge);
  592. ps_bridge->aux.name = "parade-ps8640-aux";
  593. ps_bridge->aux.dev = dev;
  594. ps_bridge->aux.transfer = ps8640_aux_transfer;
  595. ps_bridge->aux.wait_hpd_asserted = ps8640_wait_hpd_asserted;
  596. drm_dp_aux_init(&ps_bridge->aux);
  597. pm_runtime_enable(dev);
  598. /*
  599. * Powering on ps8640 takes ~300ms. To avoid wasting time on power
  600. * cycling ps8640 too often, set autosuspend_delay to 2000ms to ensure
  601. * the bridge wouldn't suspend in between each _aux_transfer_msg() call
  602. * during EDID read (~20ms in my experiment) and in between the last
  603. * _aux_transfer_msg() call during EDID read and the _pre_enable() call
  604. * (~100ms in my experiment).
  605. */
  606. pm_runtime_set_autosuspend_delay(dev, 2000);
  607. pm_runtime_use_autosuspend(dev);
  608. pm_suspend_ignore_children(dev, true);
  609. ret = devm_add_action_or_reset(dev, ps8640_runtime_disable, dev);
  610. if (ret)
  611. return ret;
  612. ret = devm_of_dp_aux_populate_bus(&ps_bridge->aux, ps8640_bridge_link_panel);
  613. /*
  614. * If devm_of_dp_aux_populate_bus() returns -ENODEV then it's up to
  615. * usa to call ps8640_bridge_link_panel() directly. NOTE: in this case
  616. * the function is allowed to -EPROBE_DEFER.
  617. */
  618. if (ret == -ENODEV)
  619. return ps8640_bridge_link_panel(&ps_bridge->aux);
  620. return ret;
  621. }
  622. static const struct of_device_id ps8640_match[] = {
  623. { .compatible = "parade,ps8640" },
  624. { }
  625. };
  626. MODULE_DEVICE_TABLE(of, ps8640_match);
  627. static struct i2c_driver ps8640_driver = {
  628. .probe = ps8640_probe,
  629. .driver = {
  630. .name = "ps8640",
  631. .of_match_table = ps8640_match,
  632. .pm = &ps8640_pm_ops,
  633. },
  634. };
  635. module_i2c_driver(ps8640_driver);
  636. MODULE_AUTHOR("Jitao Shi <jitao.shi@mediatek.com>");
  637. MODULE_AUTHOR("CK Hu <ck.hu@mediatek.com>");
  638. MODULE_AUTHOR("Enric Balletbo i Serra <enric.balletbo@collabora.com>");
  639. MODULE_DESCRIPTION("PARADE ps8640 DSI-eDP converter driver");
  640. MODULE_LICENSE("GPL v2");