udl-kms: use spin_lock_irq instead of spin_lock_irqsave
authorMikulas Patocka <mpatocka@redhat.com>
Sun, 3 Jun 2018 14:41:02 +0000 (16:41 +0200)
committerDave Airlie <airlied@redhat.com>
Mon, 30 Jul 2018 22:11:12 +0000 (08:11 +1000)
spin_lock_irqsave and spin_unlock_irqrestore is inteded to be called from
a context where it is unknown if interrupts are enabled or disabled (such
as interrupt handlers). From a process context, we should call
spin_lock_irq and spin_unlock_irq, that avoids the costly pushf and popf
instructions.

Signed-off-by: Mikulas Patocka <mpatocka@redhat.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
drivers/gpu/drm/udl/udl_main.c
drivers/gpu/drm/udl/udl_modeset.c

index 7e9ad926926ae3f8d60903e1a44d44efe652800f..f455f095a14685d234569eaed56121d6269393b1 100644 (file)
@@ -170,7 +170,6 @@ static void udl_free_urb_list(struct drm_device *dev)
        struct list_head *node;
        struct urb_node *unode;
        struct urb *urb;
-       unsigned long flags;
 
        DRM_DEBUG("Waiting for completes and freeing all render urbs\n");
 
@@ -178,12 +177,12 @@ static void udl_free_urb_list(struct drm_device *dev)
        while (count--) {
                down(&udl->urbs.limit_sem);
 
-               spin_lock_irqsave(&udl->urbs.lock, flags);
+               spin_lock_irq(&udl->urbs.lock);
 
                node = udl->urbs.list.next; /* have reserved one with sem */
                list_del_init(node);
 
-               spin_unlock_irqrestore(&udl->urbs.lock, flags);
+               spin_unlock_irq(&udl->urbs.lock);
 
                unode = list_entry(node, struct urb_node, entry);
                urb = unode->urb;
@@ -268,7 +267,6 @@ struct urb *udl_get_urb(struct drm_device *dev)
        struct list_head *entry;
        struct urb_node *unode;
        struct urb *urb = NULL;
-       unsigned long flags;
 
        /* Wait for an in-flight buffer to complete and get re-queued */
        ret = down_timeout(&udl->urbs.limit_sem, GET_URB_TIMEOUT);
@@ -279,14 +277,14 @@ struct urb *udl_get_urb(struct drm_device *dev)
                goto error;
        }
 
-       spin_lock_irqsave(&udl->urbs.lock, flags);
+       spin_lock_irq(&udl->urbs.lock);
 
        BUG_ON(list_empty(&udl->urbs.list)); /* reserved one with limit_sem */
        entry = udl->urbs.list.next;
        list_del_init(entry);
        udl->urbs.available--;
 
-       spin_unlock_irqrestore(&udl->urbs.lock, flags);
+       spin_unlock_irq(&udl->urbs.lock);
 
        unode = list_entry(entry, struct urb_node, entry);
        urb = unode->urb;
index 5bcae76497959bf3a14ba483df525eb052dd6300..98c6a58bcb0792075590807a24015e08785aeeaa 100644 (file)
@@ -366,7 +366,6 @@ static int udl_crtc_page_flip(struct drm_crtc *crtc,
 {
        struct udl_framebuffer *ufb = to_udl_fb(fb);
        struct drm_device *dev = crtc->dev;
-       unsigned long flags;
 
        struct drm_framebuffer *old_fb = crtc->primary->fb;
        if (old_fb) {
@@ -377,10 +376,10 @@ static int udl_crtc_page_flip(struct drm_crtc *crtc,
 
        udl_handle_damage(ufb, 0, 0, fb->width, fb->height);
 
-       spin_lock_irqsave(&dev->event_lock, flags);
+       spin_lock_irq(&dev->event_lock);
        if (event)
                drm_crtc_send_vblank_event(crtc, event);
-       spin_unlock_irqrestore(&dev->event_lock, flags);
+       spin_unlock_irq(&dev->event_lock);
        crtc->primary->fb = fb;
 
        return 0;