aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/udl
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2014-10-14 03:39:08 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2014-10-14 03:39:08 -0400
commit2d65a9f48fcdf7866aab6457bc707ca233e0c791 (patch)
treef93e5838d6ac2e59434367f4ff905f7d9c45fc2b /drivers/gpu/drm/udl
parentda92da3638a04894afdca8b99e973ddd20268471 (diff)
parentdfda0df3426483cf5fc7441f23f318edbabecb03 (diff)
Merge branch 'drm-next' of git://people.freedesktop.org/~airlied/linux
Pull drm updates from Dave Airlie: "This is the main git pull for the drm, I pretty much froze major pulls at -rc5/6 time, and haven't had much fallout, so will probably continue doing that. Lots of changes all over, big internal header cleanup to make it clear drm features are legacy things and what are things that modern KMS drivers should be using. Also big move to use the new generic fences in all the TTM drivers. core: atomic prep work, vblank rework changes, allows immediate vblank disables major header reworking and cleanups to better delinate legacy interfaces from what KMS drivers should be using. cursor planes locking fixes ttm: move to generic fences (affects all TTM drivers) ppc64 caching fixes radeon: userptr support, uvd for old asics, reset rework for fence changes better buffer placement changes, dpm feature enablement hdmi audio support fixes intel: Cherryview work, 180 degree rotation, skylake prep work, execlist command submission full ppgtt prep work cursor improvements edid caching, vdd handling improvements nouveau: fence reworking kepler memory clock work gt21x clock work fan control improvements hdmi infoframe fixes DP audio ast: ppc64 fixes caching fix rcar: rcar-du DT support ipuv3: prep work for capture support msm: LVDS support for mdp4, new panel, gpu refactoring exynos: exynos3250 SoC support, drop bad mmap interface, mipi dsi changes, and component match support" * 'drm-next' of git://people.freedesktop.org/~airlied/linux: (640 commits) drm/mst: rework payload table allocation to conform better. drm/ast: Fix HW cursor image drm/radeon/kv: add uvd/vce info to dpm debugfs output drm/radeon/ci: add uvd/vce info to dpm debugfs output drm/radeon: export reservation_object from dmabuf to ttm drm/radeon: cope with foreign fences inside the reservation object drm/radeon: cope with foreign fences inside display drm/core: use helper to check driver features drm/radeon/cik: write gfx ucode version to ucode addr reg drm/radeon/si: print full CS when we hit a packet 0 drm/radeon: remove unecessary includes drm/radeon/combios: declare legacy_connector_convert as static drm/radeon/atombios: declare connector convert tables as static drm/radeon: drop btc_get_max_clock_from_voltage_dependency_table drm/radeon/dpm: drop clk/voltage dependency filters for BTC drm/radeon/dpm: drop clk/voltage dependency filters for CI drm/radeon/dpm: drop clk/voltage dependency filters for SI drm/radeon/dpm: drop clk/voltage dependency filters for NI drm/radeon: disable audio when we disable hdmi (v2) drm/radeon: split audio enable between eg and r600 (v2) ...
Diffstat (limited to 'drivers/gpu/drm/udl')
-rw-r--r--drivers/gpu/drm/udl/Kconfig3
-rw-r--r--drivers/gpu/drm/udl/udl_connector.c4
-rw-r--r--drivers/gpu/drm/udl/udl_drv.c102
-rw-r--r--drivers/gpu/drm/udl/udl_drv.h2
-rw-r--r--drivers/gpu/drm/udl/udl_fb.c3
-rw-r--r--drivers/gpu/drm/udl/udl_main.c8
6 files changed, 75 insertions, 47 deletions
diff --git a/drivers/gpu/drm/udl/Kconfig b/drivers/gpu/drm/udl/Kconfig
index f02528686cd5..613ab0622d6e 100644
--- a/drivers/gpu/drm/udl/Kconfig
+++ b/drivers/gpu/drm/udl/Kconfig
@@ -1,8 +1,9 @@
1config DRM_UDL 1config DRM_UDL
2 tristate "DisplayLink" 2 tristate "DisplayLink"
3 depends on DRM 3 depends on DRM
4 depends on USB_SUPPORT
4 depends on USB_ARCH_HAS_HCD 5 depends on USB_ARCH_HAS_HCD
5 select DRM_USB 6 select USB
6 select FB_SYS_FILLRECT 7 select FB_SYS_FILLRECT
7 select FB_SYS_COPYAREA 8 select FB_SYS_COPYAREA
8 select FB_SYS_IMAGEBLIT 9 select FB_SYS_IMAGEBLIT
diff --git a/drivers/gpu/drm/udl/udl_connector.c b/drivers/gpu/drm/udl/udl_connector.c
index e026a9e2942a..0110d95522f3 100644
--- a/drivers/gpu/drm/udl/udl_connector.c
+++ b/drivers/gpu/drm/udl/udl_connector.c
@@ -34,8 +34,8 @@ static u8 *udl_get_edid(struct udl_device *udl)
34 goto error; 34 goto error;
35 35
36 for (i = 0; i < EDID_LENGTH; i++) { 36 for (i = 0; i < EDID_LENGTH; i++) {
37 ret = usb_control_msg(udl->ddev->usbdev, 37 ret = usb_control_msg(udl->udev,
38 usb_rcvctrlpipe(udl->ddev->usbdev, 0), (0x02), 38 usb_rcvctrlpipe(udl->udev, 0), (0x02),
39 (0x80 | (0x02 << 5)), i << 8, 0xA1, rbuf, 2, 39 (0x80 | (0x02 << 5)), i << 8, 0xA1, rbuf, 2,
40 HZ); 40 HZ);
41 if (ret < 1) { 41 if (ret < 1) {
diff --git a/drivers/gpu/drm/udl/udl_drv.c b/drivers/gpu/drm/udl/udl_drv.c
index 3ddd6cd98ac1..8607e9e513db 100644
--- a/drivers/gpu/drm/udl/udl_drv.c
+++ b/drivers/gpu/drm/udl/udl_drv.c
@@ -7,48 +7,13 @@
7 */ 7 */
8 8
9#include <linux/module.h> 9#include <linux/module.h>
10#include <drm/drm_usb.h> 10#include <drm/drmP.h>
11#include <drm/drm_crtc_helper.h> 11#include <drm/drm_crtc_helper.h>
12#include "udl_drv.h" 12#include "udl_drv.h"
13 13
14static struct drm_driver driver; 14static int udl_driver_set_busid(struct drm_device *d, struct drm_master *m)
15
16/*
17 * There are many DisplayLink-based graphics products, all with unique PIDs.
18 * So we match on DisplayLink's VID + Vendor-Defined Interface Class (0xff)
19 * We also require a match on SubClass (0x00) and Protocol (0x00),
20 * which is compatible with all known USB 2.0 era graphics chips and firmware,
21 * but allows DisplayLink to increment those for any future incompatible chips
22 */
23static struct usb_device_id id_table[] = {
24 {.idVendor = 0x17e9, .bInterfaceClass = 0xff,
25 .bInterfaceSubClass = 0x00,
26 .bInterfaceProtocol = 0x00,
27 .match_flags = USB_DEVICE_ID_MATCH_VENDOR |
28 USB_DEVICE_ID_MATCH_INT_CLASS |
29 USB_DEVICE_ID_MATCH_INT_SUBCLASS |
30 USB_DEVICE_ID_MATCH_INT_PROTOCOL,},
31 {},
32};
33MODULE_DEVICE_TABLE(usb, id_table);
34
35MODULE_LICENSE("GPL");
36
37static int udl_usb_probe(struct usb_interface *interface,
38 const struct usb_device_id *id)
39{ 15{
40 return drm_get_usb_dev(interface, id, &driver); 16 return 0;
41}
42
43static void udl_usb_disconnect(struct usb_interface *interface)
44{
45 struct drm_device *dev = usb_get_intfdata(interface);
46
47 drm_kms_helper_poll_disable(dev);
48 drm_connector_unplug_all(dev);
49 udl_fbdev_unplug(dev);
50 udl_drop_usb(dev);
51 drm_unplug_dev(dev);
52} 17}
53 18
54static const struct vm_operations_struct udl_gem_vm_ops = { 19static const struct vm_operations_struct udl_gem_vm_ops = {
@@ -75,6 +40,7 @@ static struct drm_driver driver = {
75 .driver_features = DRIVER_MODESET | DRIVER_GEM | DRIVER_PRIME, 40 .driver_features = DRIVER_MODESET | DRIVER_GEM | DRIVER_PRIME,
76 .load = udl_driver_load, 41 .load = udl_driver_load,
77 .unload = udl_driver_unload, 42 .unload = udl_driver_unload,
43 .set_busid = udl_driver_set_busid,
78 44
79 /* gem hooks */ 45 /* gem hooks */
80 .gem_free_object = udl_gem_free_object, 46 .gem_free_object = udl_gem_free_object,
@@ -96,6 +62,61 @@ static struct drm_driver driver = {
96 .patchlevel = DRIVER_PATCHLEVEL, 62 .patchlevel = DRIVER_PATCHLEVEL,
97}; 63};
98 64
65static int udl_usb_probe(struct usb_interface *interface,
66 const struct usb_device_id *id)
67{
68 struct usb_device *udev = interface_to_usbdev(interface);
69 struct drm_device *dev;
70 int r;
71
72 dev = drm_dev_alloc(&driver, &interface->dev);
73 if (!dev)
74 return -ENOMEM;
75
76 r = drm_dev_register(dev, (unsigned long)udev);
77 if (r)
78 goto err_free;
79
80 usb_set_intfdata(interface, dev);
81 DRM_INFO("Initialized udl on minor %d\n", dev->primary->index);
82
83 return 0;
84
85err_free:
86 drm_dev_unref(dev);
87 return r;
88}
89
90static void udl_usb_disconnect(struct usb_interface *interface)
91{
92 struct drm_device *dev = usb_get_intfdata(interface);
93
94 drm_kms_helper_poll_disable(dev);
95 drm_connector_unplug_all(dev);
96 udl_fbdev_unplug(dev);
97 udl_drop_usb(dev);
98 drm_unplug_dev(dev);
99}
100
101/*
102 * There are many DisplayLink-based graphics products, all with unique PIDs.
103 * So we match on DisplayLink's VID + Vendor-Defined Interface Class (0xff)
104 * We also require a match on SubClass (0x00) and Protocol (0x00),
105 * which is compatible with all known USB 2.0 era graphics chips and firmware,
106 * but allows DisplayLink to increment those for any future incompatible chips
107 */
108static struct usb_device_id id_table[] = {
109 {.idVendor = 0x17e9, .bInterfaceClass = 0xff,
110 .bInterfaceSubClass = 0x00,
111 .bInterfaceProtocol = 0x00,
112 .match_flags = USB_DEVICE_ID_MATCH_VENDOR |
113 USB_DEVICE_ID_MATCH_INT_CLASS |
114 USB_DEVICE_ID_MATCH_INT_SUBCLASS |
115 USB_DEVICE_ID_MATCH_INT_PROTOCOL,},
116 {},
117};
118MODULE_DEVICE_TABLE(usb, id_table);
119
99static struct usb_driver udl_driver = { 120static struct usb_driver udl_driver = {
100 .name = "udl", 121 .name = "udl",
101 .probe = udl_usb_probe, 122 .probe = udl_usb_probe,
@@ -105,13 +126,14 @@ static struct usb_driver udl_driver = {
105 126
106static int __init udl_init(void) 127static int __init udl_init(void)
107{ 128{
108 return drm_usb_init(&driver, &udl_driver); 129 return usb_register(&udl_driver);
109} 130}
110 131
111static void __exit udl_exit(void) 132static void __exit udl_exit(void)
112{ 133{
113 drm_usb_exit(&driver, &udl_driver); 134 usb_deregister(&udl_driver);
114} 135}
115 136
116module_init(udl_init); 137module_init(udl_init);
117module_exit(udl_exit); 138module_exit(udl_exit);
139MODULE_LICENSE("GPL");
diff --git a/drivers/gpu/drm/udl/udl_drv.h b/drivers/gpu/drm/udl/udl_drv.h
index 1fbf7b357f16..c7490a2489a7 100644
--- a/drivers/gpu/drm/udl/udl_drv.h
+++ b/drivers/gpu/drm/udl/udl_drv.h
@@ -15,6 +15,7 @@
15#define UDL_DRV_H 15#define UDL_DRV_H
16 16
17#include <linux/usb.h> 17#include <linux/usb.h>
18#include <drm/drm_gem.h>
18 19
19#define DRIVER_NAME "udl" 20#define DRIVER_NAME "udl"
20#define DRIVER_DESC "DisplayLink" 21#define DRIVER_DESC "DisplayLink"
@@ -47,6 +48,7 @@ struct udl_fbdev;
47struct udl_device { 48struct udl_device {
48 struct device *dev; 49 struct device *dev;
49 struct drm_device *ddev; 50 struct drm_device *ddev;
51 struct usb_device *udev;
50 52
51 int sku_pixel_limit; 53 int sku_pixel_limit;
52 54
diff --git a/drivers/gpu/drm/udl/udl_fb.c b/drivers/gpu/drm/udl/udl_fb.c
index d1da339843ca..8cbcb4589bd3 100644
--- a/drivers/gpu/drm/udl/udl_fb.c
+++ b/drivers/gpu/drm/udl/udl_fb.c
@@ -472,7 +472,8 @@ udl_framebuffer_init(struct drm_device *dev,
472static int udlfb_create(struct drm_fb_helper *helper, 472static int udlfb_create(struct drm_fb_helper *helper,
473 struct drm_fb_helper_surface_size *sizes) 473 struct drm_fb_helper_surface_size *sizes)
474{ 474{
475 struct udl_fbdev *ufbdev = (struct udl_fbdev *)helper; 475 struct udl_fbdev *ufbdev =
476 container_of(helper, struct udl_fbdev, helper);
476 struct drm_device *dev = ufbdev->helper.dev; 477 struct drm_device *dev = ufbdev->helper.dev;
477 struct fb_info *info; 478 struct fb_info *info;
478 struct device *device = dev->dev; 479 struct device *device = dev->dev;
diff --git a/drivers/gpu/drm/udl/udl_main.c b/drivers/gpu/drm/udl/udl_main.c
index 42795674bc07..33dbfb2c4748 100644
--- a/drivers/gpu/drm/udl/udl_main.c
+++ b/drivers/gpu/drm/udl/udl_main.c
@@ -202,7 +202,7 @@ static int udl_alloc_urb_list(struct drm_device *dev, int count, size_t size)
202 } 202 }
203 unode->urb = urb; 203 unode->urb = urb;
204 204
205 buf = usb_alloc_coherent(udl->ddev->usbdev, MAX_TRANSFER, GFP_KERNEL, 205 buf = usb_alloc_coherent(udl->udev, MAX_TRANSFER, GFP_KERNEL,
206 &urb->transfer_dma); 206 &urb->transfer_dma);
207 if (!buf) { 207 if (!buf) {
208 kfree(unode); 208 kfree(unode);
@@ -211,7 +211,7 @@ static int udl_alloc_urb_list(struct drm_device *dev, int count, size_t size)
211 } 211 }
212 212
213 /* urb->transfer_buffer_length set to actual before submit */ 213 /* urb->transfer_buffer_length set to actual before submit */
214 usb_fill_bulk_urb(urb, udl->ddev->usbdev, usb_sndbulkpipe(udl->ddev->usbdev, 1), 214 usb_fill_bulk_urb(urb, udl->udev, usb_sndbulkpipe(udl->udev, 1),
215 buf, size, udl_urb_completion, unode); 215 buf, size, udl_urb_completion, unode);
216 urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP; 216 urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
217 217
@@ -282,6 +282,7 @@ int udl_submit_urb(struct drm_device *dev, struct urb *urb, size_t len)
282 282
283int udl_driver_load(struct drm_device *dev, unsigned long flags) 283int udl_driver_load(struct drm_device *dev, unsigned long flags)
284{ 284{
285 struct usb_device *udev = (void*)flags;
285 struct udl_device *udl; 286 struct udl_device *udl;
286 int ret = -ENOMEM; 287 int ret = -ENOMEM;
287 288
@@ -290,10 +291,11 @@ int udl_driver_load(struct drm_device *dev, unsigned long flags)
290 if (!udl) 291 if (!udl)
291 return -ENOMEM; 292 return -ENOMEM;
292 293
294 udl->udev = udev;
293 udl->ddev = dev; 295 udl->ddev = dev;
294 dev->dev_private = udl; 296 dev->dev_private = udl;
295 297
296 if (!udl_parse_vendor_descriptor(dev, dev->usbdev)) { 298 if (!udl_parse_vendor_descriptor(dev, udl->udev)) {
297 ret = -ENODEV; 299 ret = -ENODEV;
298 DRM_ERROR("firmware not recognized. Assume incompatible device\n"); 300 DRM_ERROR("firmware not recognized. Assume incompatible device\n");
299 goto err; 301 goto err;