drm_usb.c 2.3 KB

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