drm_usb.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. #include <drm/drmP.h>
  2. #include <linux/usb.h>
  3. #include <linux/module.h>
  4. int drm_get_usb_dev(struct usb_interface *interface,
  5. const struct usb_device_id *id,
  6. struct drm_driver *driver)
  7. {
  8. struct drm_device *dev;
  9. struct usb_device *usbdev;
  10. int ret;
  11. DRM_DEBUG("\n");
  12. dev = kzalloc(sizeof(*dev), GFP_KERNEL);
  13. if (!dev)
  14. return -ENOMEM;
  15. usbdev = interface_to_usbdev(interface);
  16. dev->usbdev = usbdev;
  17. dev->dev = &interface->dev;
  18. mutex_lock(&drm_global_mutex);
  19. ret = drm_fill_in_dev(dev, NULL, driver);
  20. if (ret) {
  21. printk(KERN_ERR "DRM: Fill_in_dev failed.\n");
  22. goto err_g1;
  23. }
  24. usb_set_intfdata(interface, dev);
  25. ret = drm_get_minor(dev, &dev->control, DRM_MINOR_CONTROL);
  26. if (ret)
  27. goto err_g1;
  28. if (drm_core_check_feature(dev, DRIVER_RENDER) && drm_rnodes) {
  29. ret = drm_get_minor(dev, &dev->render, DRM_MINOR_RENDER);
  30. if (ret)
  31. goto err_g11;
  32. }
  33. ret = drm_get_minor(dev, &dev->primary, DRM_MINOR_LEGACY);
  34. if (ret)
  35. goto err_g2;
  36. if (dev->driver->load) {
  37. ret = dev->driver->load(dev, 0);
  38. if (ret)
  39. goto err_g3;
  40. }
  41. /* setup the grouping for the legacy output */
  42. ret = drm_mode_group_init_legacy_group(dev,
  43. &dev->primary->mode_group);
  44. if (ret)
  45. goto err_g3;
  46. list_add_tail(&dev->driver_item, &driver->device_list);
  47. mutex_unlock(&drm_global_mutex);
  48. DRM_INFO("Initialized %s %d.%d.%d %s on minor %d\n",
  49. driver->name, driver->major, driver->minor, driver->patchlevel,
  50. driver->date, dev->primary->index);
  51. return 0;
  52. err_g3:
  53. drm_put_minor(&dev->primary);
  54. err_g2:
  55. if (dev->render)
  56. drm_put_minor(&dev->render);
  57. err_g11:
  58. drm_put_minor(&dev->control);
  59. err_g1:
  60. kfree(dev);
  61. mutex_unlock(&drm_global_mutex);
  62. return ret;
  63. }
  64. EXPORT_SYMBOL(drm_get_usb_dev);
  65. static int drm_usb_get_irq(struct drm_device *dev)
  66. {
  67. return 0;
  68. }
  69. static const char *drm_usb_get_name(struct drm_device *dev)
  70. {
  71. return "USB";
  72. }
  73. static int drm_usb_set_busid(struct drm_device *dev,
  74. struct drm_master *master)
  75. {
  76. return 0;
  77. }
  78. static struct drm_bus drm_usb_bus = {
  79. .bus_type = DRIVER_BUS_USB,
  80. .get_irq = drm_usb_get_irq,
  81. .get_name = drm_usb_get_name,
  82. .set_busid = drm_usb_set_busid,
  83. };
  84. int drm_usb_init(struct drm_driver *driver, struct usb_driver *udriver)
  85. {
  86. int res;
  87. DRM_DEBUG("\n");
  88. INIT_LIST_HEAD(&driver->device_list);
  89. driver->kdriver.usb = udriver;
  90. driver->bus = &drm_usb_bus;
  91. res = usb_register(udriver);
  92. return res;
  93. }
  94. EXPORT_SYMBOL(drm_usb_init);
  95. void drm_usb_exit(struct drm_driver *driver,
  96. struct usb_driver *udriver)
  97. {
  98. usb_deregister(udriver);
  99. }
  100. EXPORT_SYMBOL(drm_usb_exit);
  101. MODULE_AUTHOR("David Airlie");
  102. MODULE_DESCRIPTION("USB DRM support");
  103. MODULE_LICENSE("GPL and additional rights");