nxp-ptn3460.c 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * NXP PTN3460 DP/LVDS bridge driver
  4. *
  5. * Copyright (C) 2013 Google, Inc.
  6. */
  7. #include <linux/delay.h>
  8. #include <linux/gpio/consumer.h>
  9. #include <linux/i2c.h>
  10. #include <linux/module.h>
  11. #include <linux/of.h>
  12. #include <drm/drm_atomic_helper.h>
  13. #include <drm/drm_bridge.h>
  14. #include <drm/drm_crtc.h>
  15. #include <drm/drm_edid.h>
  16. #include <drm/drm_of.h>
  17. #include <drm/drm_panel.h>
  18. #include <drm/drm_print.h>
  19. #include <drm/drm_probe_helper.h>
  20. #define PTN3460_EDID_ADDR 0x0
  21. #define PTN3460_EDID_EMULATION_ADDR 0x84
  22. #define PTN3460_EDID_ENABLE_EMULATION 0
  23. #define PTN3460_EDID_EMULATION_SELECTION 1
  24. #define PTN3460_EDID_SRAM_LOAD_ADDR 0x85
  25. struct ptn3460_bridge {
  26. struct drm_connector connector;
  27. struct i2c_client *client;
  28. struct drm_bridge bridge;
  29. struct drm_bridge *panel_bridge;
  30. struct gpio_desc *gpio_pd_n;
  31. struct gpio_desc *gpio_rst_n;
  32. u32 edid_emulation;
  33. bool enabled;
  34. };
  35. static inline struct ptn3460_bridge *
  36. bridge_to_ptn3460(struct drm_bridge *bridge)
  37. {
  38. return container_of(bridge, struct ptn3460_bridge, bridge);
  39. }
  40. static inline struct ptn3460_bridge *
  41. connector_to_ptn3460(struct drm_connector *connector)
  42. {
  43. return container_of(connector, struct ptn3460_bridge, connector);
  44. }
  45. static int ptn3460_read_bytes(struct ptn3460_bridge *ptn_bridge, char addr,
  46. u8 *buf, int len)
  47. {
  48. int ret;
  49. ret = i2c_master_send(ptn_bridge->client, &addr, 1);
  50. if (ret <= 0) {
  51. DRM_ERROR("Failed to send i2c command, ret=%d\n", ret);
  52. return ret;
  53. }
  54. ret = i2c_master_recv(ptn_bridge->client, buf, len);
  55. if (ret <= 0) {
  56. DRM_ERROR("Failed to recv i2c data, ret=%d\n", ret);
  57. return ret;
  58. }
  59. return 0;
  60. }
  61. static int ptn3460_write_byte(struct ptn3460_bridge *ptn_bridge, char addr,
  62. char val)
  63. {
  64. int ret;
  65. char buf[2];
  66. buf[0] = addr;
  67. buf[1] = val;
  68. ret = i2c_master_send(ptn_bridge->client, buf, ARRAY_SIZE(buf));
  69. if (ret <= 0) {
  70. DRM_ERROR("Failed to send i2c command, ret=%d\n", ret);
  71. return ret;
  72. }
  73. return 0;
  74. }
  75. static int ptn3460_select_edid(struct ptn3460_bridge *ptn_bridge)
  76. {
  77. int ret;
  78. char val;
  79. /* Load the selected edid into SRAM (accessed at PTN3460_EDID_ADDR) */
  80. ret = ptn3460_write_byte(ptn_bridge, PTN3460_EDID_SRAM_LOAD_ADDR,
  81. ptn_bridge->edid_emulation);
  82. if (ret) {
  83. DRM_ERROR("Failed to transfer EDID to sram, ret=%d\n", ret);
  84. return ret;
  85. }
  86. /* Enable EDID emulation and select the desired EDID */
  87. val = 1 << PTN3460_EDID_ENABLE_EMULATION |
  88. ptn_bridge->edid_emulation << PTN3460_EDID_EMULATION_SELECTION;
  89. ret = ptn3460_write_byte(ptn_bridge, PTN3460_EDID_EMULATION_ADDR, val);
  90. if (ret) {
  91. DRM_ERROR("Failed to write EDID value, ret=%d\n", ret);
  92. return ret;
  93. }
  94. return 0;
  95. }
  96. static void ptn3460_pre_enable(struct drm_bridge *bridge)
  97. {
  98. struct ptn3460_bridge *ptn_bridge = bridge_to_ptn3460(bridge);
  99. int ret;
  100. if (ptn_bridge->enabled)
  101. return;
  102. gpiod_set_value(ptn_bridge->gpio_pd_n, 1);
  103. gpiod_set_value(ptn_bridge->gpio_rst_n, 0);
  104. usleep_range(10, 20);
  105. gpiod_set_value(ptn_bridge->gpio_rst_n, 1);
  106. /*
  107. * There's a bug in the PTN chip where it falsely asserts hotplug before
  108. * it is fully functional. We're forced to wait for the maximum start up
  109. * time specified in the chip's datasheet to make sure we're really up.
  110. */
  111. msleep(90);
  112. ret = ptn3460_select_edid(ptn_bridge);
  113. if (ret)
  114. DRM_ERROR("Select EDID failed ret=%d\n", ret);
  115. ptn_bridge->enabled = true;
  116. }
  117. static void ptn3460_disable(struct drm_bridge *bridge)
  118. {
  119. struct ptn3460_bridge *ptn_bridge = bridge_to_ptn3460(bridge);
  120. if (!ptn_bridge->enabled)
  121. return;
  122. ptn_bridge->enabled = false;
  123. gpiod_set_value(ptn_bridge->gpio_rst_n, 1);
  124. gpiod_set_value(ptn_bridge->gpio_pd_n, 0);
  125. }
  126. static struct edid *ptn3460_get_edid(struct drm_bridge *bridge,
  127. struct drm_connector *connector)
  128. {
  129. struct ptn3460_bridge *ptn_bridge = bridge_to_ptn3460(bridge);
  130. bool power_off;
  131. u8 *edid;
  132. int ret;
  133. power_off = !ptn_bridge->enabled;
  134. ptn3460_pre_enable(&ptn_bridge->bridge);
  135. edid = kmalloc(EDID_LENGTH, GFP_KERNEL);
  136. if (!edid) {
  137. DRM_ERROR("Failed to allocate EDID\n");
  138. goto out;
  139. }
  140. ret = ptn3460_read_bytes(ptn_bridge, PTN3460_EDID_ADDR, edid,
  141. EDID_LENGTH);
  142. if (ret) {
  143. kfree(edid);
  144. edid = NULL;
  145. goto out;
  146. }
  147. out:
  148. if (power_off)
  149. ptn3460_disable(&ptn_bridge->bridge);
  150. return (struct edid *)edid;
  151. }
  152. static int ptn3460_connector_get_modes(struct drm_connector *connector)
  153. {
  154. struct ptn3460_bridge *ptn_bridge = connector_to_ptn3460(connector);
  155. struct edid *edid;
  156. int num_modes;
  157. edid = ptn3460_get_edid(&ptn_bridge->bridge, connector);
  158. drm_connector_update_edid_property(connector, edid);
  159. num_modes = drm_add_edid_modes(connector, edid);
  160. kfree(edid);
  161. return num_modes;
  162. }
  163. static const struct drm_connector_helper_funcs ptn3460_connector_helper_funcs = {
  164. .get_modes = ptn3460_connector_get_modes,
  165. };
  166. static const struct drm_connector_funcs ptn3460_connector_funcs = {
  167. .fill_modes = drm_helper_probe_single_connector_modes,
  168. .destroy = drm_connector_cleanup,
  169. .reset = drm_atomic_helper_connector_reset,
  170. .atomic_duplicate_state = drm_atomic_helper_connector_duplicate_state,
  171. .atomic_destroy_state = drm_atomic_helper_connector_destroy_state,
  172. };
  173. static int ptn3460_bridge_attach(struct drm_bridge *bridge,
  174. enum drm_bridge_attach_flags flags)
  175. {
  176. struct ptn3460_bridge *ptn_bridge = bridge_to_ptn3460(bridge);
  177. int ret;
  178. /* Let this driver create connector if requested */
  179. ret = drm_bridge_attach(bridge->encoder, ptn_bridge->panel_bridge,
  180. bridge, flags | DRM_BRIDGE_ATTACH_NO_CONNECTOR);
  181. if (ret < 0)
  182. return ret;
  183. if (flags & DRM_BRIDGE_ATTACH_NO_CONNECTOR)
  184. return 0;
  185. if (!bridge->encoder) {
  186. DRM_ERROR("Parent encoder object not found");
  187. return -ENODEV;
  188. }
  189. ptn_bridge->connector.polled = DRM_CONNECTOR_POLL_HPD;
  190. ret = drm_connector_init(bridge->dev, &ptn_bridge->connector,
  191. &ptn3460_connector_funcs, DRM_MODE_CONNECTOR_LVDS);
  192. if (ret) {
  193. DRM_ERROR("Failed to initialize connector with drm\n");
  194. return ret;
  195. }
  196. drm_connector_helper_add(&ptn_bridge->connector,
  197. &ptn3460_connector_helper_funcs);
  198. drm_connector_register(&ptn_bridge->connector);
  199. drm_connector_attach_encoder(&ptn_bridge->connector,
  200. bridge->encoder);
  201. drm_helper_hpd_irq_event(ptn_bridge->connector.dev);
  202. return ret;
  203. }
  204. static const struct drm_bridge_funcs ptn3460_bridge_funcs = {
  205. .pre_enable = ptn3460_pre_enable,
  206. .disable = ptn3460_disable,
  207. .attach = ptn3460_bridge_attach,
  208. .get_edid = ptn3460_get_edid,
  209. };
  210. static int ptn3460_probe(struct i2c_client *client,
  211. const struct i2c_device_id *id)
  212. {
  213. struct device *dev = &client->dev;
  214. struct ptn3460_bridge *ptn_bridge;
  215. struct drm_bridge *panel_bridge;
  216. int ret;
  217. ptn_bridge = devm_kzalloc(dev, sizeof(*ptn_bridge), GFP_KERNEL);
  218. if (!ptn_bridge) {
  219. return -ENOMEM;
  220. }
  221. panel_bridge = devm_drm_of_get_bridge(dev, dev->of_node, 0, 0);
  222. if (IS_ERR(panel_bridge))
  223. return PTR_ERR(panel_bridge);
  224. ptn_bridge->panel_bridge = panel_bridge;
  225. ptn_bridge->client = client;
  226. ptn_bridge->gpio_pd_n = devm_gpiod_get(&client->dev, "powerdown",
  227. GPIOD_OUT_HIGH);
  228. if (IS_ERR(ptn_bridge->gpio_pd_n)) {
  229. ret = PTR_ERR(ptn_bridge->gpio_pd_n);
  230. dev_err(dev, "cannot get gpio_pd_n %d\n", ret);
  231. return ret;
  232. }
  233. /*
  234. * Request the reset pin low to avoid the bridge being
  235. * initialized prematurely
  236. */
  237. ptn_bridge->gpio_rst_n = devm_gpiod_get(&client->dev, "reset",
  238. GPIOD_OUT_LOW);
  239. if (IS_ERR(ptn_bridge->gpio_rst_n)) {
  240. ret = PTR_ERR(ptn_bridge->gpio_rst_n);
  241. DRM_ERROR("cannot get gpio_rst_n %d\n", ret);
  242. return ret;
  243. }
  244. ret = of_property_read_u32(dev->of_node, "edid-emulation",
  245. &ptn_bridge->edid_emulation);
  246. if (ret) {
  247. dev_err(dev, "Can't read EDID emulation value\n");
  248. return ret;
  249. }
  250. ptn_bridge->bridge.funcs = &ptn3460_bridge_funcs;
  251. ptn_bridge->bridge.ops = DRM_BRIDGE_OP_EDID;
  252. ptn_bridge->bridge.type = DRM_MODE_CONNECTOR_LVDS;
  253. ptn_bridge->bridge.of_node = dev->of_node;
  254. drm_bridge_add(&ptn_bridge->bridge);
  255. i2c_set_clientdata(client, ptn_bridge);
  256. return 0;
  257. }
  258. static void ptn3460_remove(struct i2c_client *client)
  259. {
  260. struct ptn3460_bridge *ptn_bridge = i2c_get_clientdata(client);
  261. drm_bridge_remove(&ptn_bridge->bridge);
  262. }
  263. static const struct i2c_device_id ptn3460_i2c_table[] = {
  264. {"ptn3460", 0},
  265. {},
  266. };
  267. MODULE_DEVICE_TABLE(i2c, ptn3460_i2c_table);
  268. static const struct of_device_id ptn3460_match[] = {
  269. { .compatible = "nxp,ptn3460" },
  270. {},
  271. };
  272. MODULE_DEVICE_TABLE(of, ptn3460_match);
  273. static struct i2c_driver ptn3460_driver = {
  274. .id_table = ptn3460_i2c_table,
  275. .probe = ptn3460_probe,
  276. .remove = ptn3460_remove,
  277. .driver = {
  278. .name = "nxp,ptn3460",
  279. .of_match_table = ptn3460_match,
  280. },
  281. };
  282. module_i2c_driver(ptn3460_driver);
  283. MODULE_AUTHOR("Sean Paul <[email protected]>");
  284. MODULE_DESCRIPTION("NXP ptn3460 eDP-LVDS converter driver");
  285. MODULE_LICENSE("GPL v2");