drm_usb.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. #include "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. ret = drm_get_minor(dev, &dev->primary, DRM_MINOR_LEGACY);
  29. if (ret)
  30. goto err_g2;
  31. if (dev->driver->load) {
  32. ret = dev->driver->load(dev, 0);
  33. if (ret)
  34. goto err_g3;
  35. }
  36. /* setup the grouping for the legacy output */
  37. ret = drm_mode_group_init_legacy_group(dev,
  38. &dev->primary->mode_group);
  39. if (ret)
  40. goto err_g3;
  41. list_add_tail(&dev->driver_item, &driver->device_list);
  42. mutex_unlock(&drm_global_mutex);
  43. DRM_INFO("Initialized %s %d.%d.%d %s on minor %d\n",
  44. driver->name, driver->major, driver->minor, driver->patchlevel,
  45. driver->date, dev->primary->index);
  46. return 0;
  47. err_g3:
  48. drm_put_minor(&dev->primary);
  49. err_g2:
  50. drm_put_minor(&dev->control);
  51. err_g1:
  52. kfree(dev);
  53. mutex_unlock(&drm_global_mutex);
  54. return ret;
  55. }
  56. EXPORT_SYMBOL(drm_get_usb_dev);
  57. static int drm_usb_get_irq(struct drm_device *dev)
  58. {
  59. return 0;
  60. }
  61. static const char *drm_usb_get_name(struct drm_device *dev)
  62. {
  63. return "USB";
  64. }
  65. static int drm_usb_set_busid(struct drm_device *dev,
  66. struct drm_master *master)
  67. {
  68. return 0;
  69. }
  70. static struct drm_bus drm_usb_bus = {
  71. .bus_type = DRIVER_BUS_USB,
  72. .get_irq = drm_usb_get_irq,
  73. .get_name = drm_usb_get_name,
  74. .set_busid = drm_usb_set_busid,
  75. };
  76. int drm_usb_init(struct drm_driver *driver, struct usb_driver *udriver)
  77. {
  78. int res;
  79. DRM_DEBUG("\n");
  80. INIT_LIST_HEAD(&driver->device_list);
  81. driver->kdriver.usb = udriver;
  82. driver->bus = &drm_usb_bus;
  83. res = usb_register(udriver);
  84. return res;
  85. }
  86. EXPORT_SYMBOL(drm_usb_init);
  87. void drm_usb_exit(struct drm_driver *driver,
  88. struct usb_driver *udriver)
  89. {
  90. usb_deregister(udriver);
  91. }
  92. EXPORT_SYMBOL(drm_usb_exit);
  93. MODULE_AUTHOR("David Airlie");
  94. MODULE_DESCRIPTION("USB DRM support");
  95. MODULE_LICENSE("GPL and additional rights");