staging: sm750fb: Remove spinlock helper function
authorLorenzo Stoakes <lstoakes@gmail.com>
Fri, 20 Mar 2015 15:22:15 +0000 (15:22 +0000)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 26 Mar 2015 12:04:48 +0000 (13:04 +0100)
This patch removes the unnecessary spinlock helper function and instead
calls spin_lock and spin_unlock directly.

This does *not* resolve sparse warnings about context imbalances but these are
spurious.

Signed-off-by: Lorenzo Stoakes <lstoakes@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/sm750fb/sm750.c

index 402bf9b0a1a208e3bf5034d803bf0cfc33644bad..4074375441c82c6bd93eb206d4d49b204522e8b2 100644 (file)
@@ -56,23 +56,6 @@ static char * g_settings = NULL;
 static int g_dualview;
 static char * g_option = NULL;
 
-/* if not use spin_lock,system will die if user load driver
- * and immediatly unload driver frequently (dual)*/
-static inline void myspin_lock(spinlock_t * sl){
-       struct lynx_share * share;
-       share = container_of(sl,struct lynx_share,slock);
-       if(share->dual){
-               spin_lock(sl);
-       }
-}
-
-static inline void myspin_unlock(spinlock_t * sl){
-       struct lynx_share * share;
-       share = container_of(sl,struct lynx_share,slock);
-       if(share->dual){
-               spin_unlock(sl);
-       }
-}
 static const struct fb_videomode lynx750_ext[] = {
        /*      1024x600-60 VESA        [1.71:1]        */
        {NULL,  60, 1024, 600, 20423, 144,  40, 18, 1, 104, 3,
@@ -209,13 +192,21 @@ static void lynxfb_ops_fillrect(struct fb_info* info,const struct fb_fillrect* r
        color = (Bpp == 1)?region->color:((u32*)info->pseudo_palette)[region->color];
        rop = ( region->rop != ROP_COPY ) ? HW_ROP2_XOR:HW_ROP2_COPY;
 
-       myspin_lock(&share->slock);
+       /*
+        * If not use spin_lock,system will die if user load driver
+        * and immediatly unload driver frequently (dual)
+        */
+       if (share->dual)
+               spin_lock(&share->slock);
+
        share->accel.de_fillrect(&share->accel,
                                                        base,pitch,Bpp,
                                                        region->dx,region->dy,
                                                        region->width,region->height,
                                                        color,rop);
-       myspin_unlock(&share->slock);
+
+       if (share->dual)
+               spin_unlock(&share->slock);
 }
 
 static void lynxfb_ops_copyarea(struct fb_info * info,const struct fb_copyarea * region)
@@ -233,12 +224,20 @@ static void lynxfb_ops_copyarea(struct fb_info * info,const struct fb_copyarea *
        pitch = info->fix.line_length;
        Bpp = info->var.bits_per_pixel >> 3;
 
-       myspin_lock(&share->slock);
+       /*
+        * If not use spin_lock, system will die if user load driver
+        * and immediatly unload driver frequently (dual)
+        */
+       if (share->dual)
+               spin_lock(&share->slock);
+
        share->accel.de_copyarea(&share->accel,
                                                        base,pitch,region->sx,region->sy,
                                                        base,pitch,Bpp,region->dx,region->dy,
                                                        region->width,region->height,HW_ROP2_COPY);
-       myspin_unlock(&share->slock);
+
+       if (share->dual)
+               spin_unlock(&share->slock);
 }
 
 static void lynxfb_ops_imageblit(struct fb_info*info,const struct fb_image* image)
@@ -272,14 +271,22 @@ static void lynxfb_ops_imageblit(struct fb_info*info,const struct fb_image* imag
        }
        return;
 _do_work:
-       myspin_lock(&share->slock);
+       /*
+        * If not use spin_lock, system will die if user load driver
+        * and immediatly unload driver frequently (dual)
+        */
+       if (share->dual)
+               spin_lock(&share->slock);
+
        share->accel.de_imageblit(&share->accel,
                                        image->data,image->width>>3,0,
                                        base,pitch,Bpp,
                                        image->dx,image->dy,
                                        image->width,image->height,
                                        fgcol,bgcol,HW_ROP2_COPY);
-       myspin_unlock(&share->slock);
+
+       if (share->dual)
+               spin_unlock(&share->slock);
 }
 
 static int lynxfb_ops_pan_display(struct fb_var_screeninfo *var,