udl_main.c 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (C) 2012 Red Hat
  4. *
  5. * based in parts on udlfb.c:
  6. * Copyright (C) 2009 Roberto De Ioris <roberto@unbit.it>
  7. * Copyright (C) 2009 Jaya Kumar <jayakumar.lkml@gmail.com>
  8. * Copyright (C) 2009 Bernie Thompson <bernie@plugable.com>
  9. */
  10. #include <linux/unaligned.h>
  11. #include <drm/drm.h>
  12. #include <drm/drm_print.h>
  13. #include <drm/drm_probe_helper.h>
  14. #include "udl_drv.h"
  15. /* -BULK_SIZE as per usb-skeleton. Can we get full page and avoid overhead? */
  16. #define BULK_SIZE 512
  17. #define NR_USB_REQUEST_CHANNEL 0x12
  18. #define MAX_TRANSFER (PAGE_SIZE*16 - BULK_SIZE)
  19. #define WRITES_IN_FLIGHT (20)
  20. #define MAX_VENDOR_DESCRIPTOR_SIZE 256
  21. #define UDL_SKU_PIXEL_LIMIT_DEFAULT 2080000
  22. static struct urb *udl_get_urb_locked(struct udl_device *udl, long timeout);
  23. /*
  24. * Try to make sense of whatever we parse. Therefore return @end on
  25. * errors, but don't fail hard.
  26. */
  27. static const u8 *udl_parse_key_value_pair(struct udl_device *udl, const u8 *pos, const u8 *end)
  28. {
  29. u16 key;
  30. u8 len;
  31. /* read key */
  32. if (pos >= end - 2)
  33. return end;
  34. key = get_unaligned_le16(pos);
  35. pos += 2;
  36. /* read value length */
  37. if (pos >= end - 1)
  38. return end;
  39. len = *pos++;
  40. /* read value */
  41. if (pos >= end - len)
  42. return end;
  43. switch (key) {
  44. case 0x0200: { /* maximum number of pixels */
  45. unsigned int sku_pixel_limit;
  46. if (len < sizeof(__le32))
  47. break;
  48. sku_pixel_limit = get_unaligned_le32(pos);
  49. if (sku_pixel_limit >= 16 * UDL_SKU_PIXEL_LIMIT_DEFAULT)
  50. break; /* almost 100 MiB, so probably bogus */
  51. udl->sku_pixel_limit = sku_pixel_limit;
  52. break;
  53. }
  54. default:
  55. break;
  56. }
  57. pos += len;
  58. return pos;
  59. }
  60. static int udl_parse_vendor_descriptor(struct udl_device *udl)
  61. {
  62. struct drm_device *dev = &udl->drm;
  63. struct usb_device *udev = udl_to_usb_device(udl);
  64. bool detected = false;
  65. void *buf;
  66. int ret;
  67. unsigned int len;
  68. const u8 *desc;
  69. const u8 *desc_end;
  70. buf = kzalloc(MAX_VENDOR_DESCRIPTOR_SIZE, GFP_KERNEL);
  71. if (!buf)
  72. return -ENOMEM;
  73. ret = usb_get_descriptor(udev, 0x5f, /* vendor specific */
  74. 0, buf, MAX_VENDOR_DESCRIPTOR_SIZE);
  75. if (ret < 0)
  76. goto out;
  77. len = ret;
  78. if (len < 5)
  79. goto out;
  80. desc = buf;
  81. desc_end = desc + len;
  82. if ((desc[0] != len) || /* descriptor length */
  83. (desc[1] != 0x5f) || /* vendor descriptor type */
  84. (desc[2] != 0x01) || /* version (2 bytes) */
  85. (desc[3] != 0x00) ||
  86. (desc[4] != len - 2)) /* length after type */
  87. goto out;
  88. desc += 5;
  89. detected = true;
  90. while (desc < desc_end)
  91. desc = udl_parse_key_value_pair(udl, desc, desc_end);
  92. out:
  93. if (!detected)
  94. drm_warn(dev, "Unrecognized vendor firmware descriptor\n");
  95. kfree(buf);
  96. return 0;
  97. }
  98. /*
  99. * Need to ensure a channel is selected before submitting URBs
  100. */
  101. int udl_select_std_channel(struct udl_device *udl)
  102. {
  103. static const u8 set_def_chn[] = {0x57, 0xCD, 0xDC, 0xA7,
  104. 0x1C, 0x88, 0x5E, 0x15,
  105. 0x60, 0xFE, 0xC6, 0x97,
  106. 0x16, 0x3D, 0x47, 0xF2};
  107. void *sendbuf;
  108. int ret;
  109. struct usb_device *udev = udl_to_usb_device(udl);
  110. sendbuf = kmemdup(set_def_chn, sizeof(set_def_chn), GFP_KERNEL);
  111. if (!sendbuf)
  112. return -ENOMEM;
  113. ret = usb_control_msg(udev, usb_sndctrlpipe(udev, 0),
  114. NR_USB_REQUEST_CHANNEL,
  115. (USB_DIR_OUT | USB_TYPE_VENDOR), 0, 0,
  116. sendbuf, sizeof(set_def_chn),
  117. USB_CTRL_SET_TIMEOUT);
  118. kfree(sendbuf);
  119. return ret < 0 ? ret : 0;
  120. }
  121. void udl_urb_completion(struct urb *urb)
  122. {
  123. struct urb_node *unode = urb->context;
  124. struct udl_device *udl = unode->dev;
  125. unsigned long flags;
  126. /* sync/async unlink faults aren't errors */
  127. if (urb->status) {
  128. if (!(urb->status == -ENOENT ||
  129. urb->status == -ECONNRESET ||
  130. urb->status == -EPROTO ||
  131. urb->status == -ESHUTDOWN)) {
  132. DRM_ERROR("%s - nonzero write bulk status received: %d\n",
  133. __func__, urb->status);
  134. }
  135. }
  136. urb->transfer_buffer_length = udl->urbs.size; /* reset to actual */
  137. spin_lock_irqsave(&udl->urbs.lock, flags);
  138. list_add_tail(&unode->entry, &udl->urbs.list);
  139. udl->urbs.available++;
  140. spin_unlock_irqrestore(&udl->urbs.lock, flags);
  141. wake_up(&udl->urbs.sleep);
  142. }
  143. static void udl_free_urb_list(struct udl_device *udl)
  144. {
  145. struct urb_node *unode;
  146. struct urb *urb;
  147. DRM_DEBUG("Waiting for completes and freeing all render urbs\n");
  148. /* keep waiting and freeing, until we've got 'em all */
  149. while (udl->urbs.count) {
  150. spin_lock_irq(&udl->urbs.lock);
  151. urb = udl_get_urb_locked(udl, MAX_SCHEDULE_TIMEOUT);
  152. udl->urbs.count--;
  153. spin_unlock_irq(&udl->urbs.lock);
  154. if (WARN_ON(!urb))
  155. break;
  156. unode = urb->context;
  157. /* Free each separately allocated piece */
  158. usb_free_coherent(urb->dev, udl->urbs.size,
  159. urb->transfer_buffer, urb->transfer_dma);
  160. usb_free_urb(urb);
  161. kfree(unode);
  162. }
  163. wake_up_all(&udl->urbs.sleep);
  164. }
  165. static int udl_alloc_urb_list(struct udl_device *udl, int count, size_t size)
  166. {
  167. struct urb *urb;
  168. struct urb_node *unode;
  169. char *buf;
  170. size_t wanted_size = count * size;
  171. struct usb_device *udev = udl_to_usb_device(udl);
  172. spin_lock_init(&udl->urbs.lock);
  173. INIT_LIST_HEAD(&udl->urbs.list);
  174. init_waitqueue_head(&udl->urbs.sleep);
  175. udl->urbs.count = 0;
  176. udl->urbs.available = 0;
  177. retry:
  178. udl->urbs.size = size;
  179. while (udl->urbs.count * size < wanted_size) {
  180. unode = kzalloc_obj(struct urb_node);
  181. if (!unode)
  182. break;
  183. unode->dev = udl;
  184. urb = usb_alloc_urb(0, GFP_KERNEL);
  185. if (!urb) {
  186. kfree(unode);
  187. break;
  188. }
  189. unode->urb = urb;
  190. buf = usb_alloc_coherent(udev, size, GFP_KERNEL,
  191. &urb->transfer_dma);
  192. if (!buf) {
  193. kfree(unode);
  194. usb_free_urb(urb);
  195. if (size > PAGE_SIZE) {
  196. size /= 2;
  197. udl_free_urb_list(udl);
  198. goto retry;
  199. }
  200. break;
  201. }
  202. /* urb->transfer_buffer_length set to actual before submit */
  203. usb_fill_bulk_urb(urb, udev, usb_sndbulkpipe(udev, 1),
  204. buf, size, udl_urb_completion, unode);
  205. urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
  206. list_add_tail(&unode->entry, &udl->urbs.list);
  207. udl->urbs.count++;
  208. udl->urbs.available++;
  209. }
  210. DRM_DEBUG("allocated %d %d byte urbs\n", udl->urbs.count, (int) size);
  211. return udl->urbs.count;
  212. }
  213. static struct urb *udl_get_urb_locked(struct udl_device *udl, long timeout)
  214. {
  215. struct urb_node *unode;
  216. assert_spin_locked(&udl->urbs.lock);
  217. /* Wait for an in-flight buffer to complete and get re-queued */
  218. if (!wait_event_lock_irq_timeout(udl->urbs.sleep,
  219. !udl->urbs.count ||
  220. !list_empty(&udl->urbs.list),
  221. udl->urbs.lock, timeout)) {
  222. DRM_INFO("wait for urb interrupted: available: %d\n",
  223. udl->urbs.available);
  224. return NULL;
  225. }
  226. if (!udl->urbs.count)
  227. return NULL;
  228. unode = list_first_entry(&udl->urbs.list, struct urb_node, entry);
  229. list_del_init(&unode->entry);
  230. udl->urbs.available--;
  231. return unode->urb;
  232. }
  233. #define GET_URB_TIMEOUT HZ
  234. struct urb *udl_get_urb(struct udl_device *udl)
  235. {
  236. struct urb *urb;
  237. spin_lock_irq(&udl->urbs.lock);
  238. urb = udl_get_urb_locked(udl, GET_URB_TIMEOUT);
  239. spin_unlock_irq(&udl->urbs.lock);
  240. return urb;
  241. }
  242. int udl_submit_urb(struct udl_device *udl, struct urb *urb, size_t len)
  243. {
  244. int ret;
  245. if (WARN_ON(len > udl->urbs.size)) {
  246. ret = -EINVAL;
  247. goto error;
  248. }
  249. urb->transfer_buffer_length = len; /* set to actual payload len */
  250. ret = usb_submit_urb(urb, GFP_ATOMIC);
  251. error:
  252. if (ret) {
  253. udl_urb_completion(urb); /* because no one else will */
  254. DRM_ERROR("usb_submit_urb error %x\n", ret);
  255. }
  256. return ret;
  257. }
  258. /* wait until all pending URBs have been processed */
  259. void udl_sync_pending_urbs(struct udl_device *udl)
  260. {
  261. struct drm_device *dev = &udl->drm;
  262. spin_lock_irq(&udl->urbs.lock);
  263. /* 2 seconds as a sane timeout */
  264. if (!wait_event_lock_irq_timeout(udl->urbs.sleep,
  265. udl->urbs.available == udl->urbs.count,
  266. udl->urbs.lock,
  267. msecs_to_jiffies(2000)))
  268. drm_err(dev, "Timeout for syncing pending URBs\n");
  269. spin_unlock_irq(&udl->urbs.lock);
  270. }
  271. int udl_init(struct udl_device *udl)
  272. {
  273. struct drm_device *dev = &udl->drm;
  274. int ret = -ENOMEM;
  275. struct device *dma_dev;
  276. DRM_DEBUG("\n");
  277. dma_dev = usb_intf_get_dma_device(to_usb_interface(dev->dev));
  278. if (dma_dev) {
  279. drm_dev_set_dma_dev(dev, dma_dev);
  280. put_device(dma_dev);
  281. } else {
  282. drm_warn(dev, "buffer sharing not supported"); /* not an error */
  283. }
  284. /*
  285. * Not all devices provide vendor descriptors with device
  286. * information. Initialize to default values of real-world
  287. * devices. It is just enough memory for FullHD.
  288. */
  289. udl->sku_pixel_limit = UDL_SKU_PIXEL_LIMIT_DEFAULT;
  290. ret = udl_parse_vendor_descriptor(udl);
  291. if (ret)
  292. goto err;
  293. if (udl_select_std_channel(udl))
  294. DRM_ERROR("Selecting channel failed\n");
  295. if (!udl_alloc_urb_list(udl, WRITES_IN_FLIGHT, MAX_TRANSFER)) {
  296. DRM_ERROR("udl_alloc_urb_list failed\n");
  297. ret = -ENOMEM;
  298. goto err;
  299. }
  300. DRM_DEBUG("\n");
  301. ret = udl_modeset_init(udl);
  302. if (ret)
  303. goto err;
  304. return 0;
  305. err:
  306. if (udl->urbs.count)
  307. udl_free_urb_list(udl);
  308. DRM_ERROR("%d\n", ret);
  309. return ret;
  310. }
  311. int udl_drop_usb(struct udl_device *udl)
  312. {
  313. udl_free_urb_list(udl);
  314. return 0;
  315. }