scsi: aacraid: Fix a potential spinlock double unlock bug
authorRaghava Aditya Renukunta <RaghavaAditya.Renukunta@microsemi.com>
Thu, 16 Feb 2017 20:51:23 +0000 (12:51 -0800)
committerMartin K. Petersen <martin.petersen@oracle.com>
Wed, 22 Feb 2017 23:41:42 +0000 (18:41 -0500)
The driver does not unlock the reply  queue spin lock after handling SMART
adapter events. Instead it might attempt to unlock an already unlocked
spin lock.

Fixed by making sure the driver locks the spin lock before freeing it.

Thank you dan for finding this issue out.

Fixes: 6223a39fe6fbbeef (scsi: aacraid: Added support for hotplug)
Reported-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Raghava Aditya Renukunta <RaghavaAditya.Renukunta@microsemi.com>
Reviewed-by: David Carroll <David.Carroll@microsemi.com>
Reviewed-by: Johannes Thumshirn <jthumshirn@suse.de>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/aacraid/commsup.c

index 1f716c01708bc591f156e61e99d85463ddd3c7ea..a2ea70d8a13ac6ef901877925ba494d4488a09b2 100644 (file)
@@ -2215,7 +2215,7 @@ static void aac_process_events(struct aac_dev *dev)
                        /* Thor AIF */
                        aac_handle_sa_aif(dev, fib);
                        aac_fib_adapter_complete(fib, (u16)sizeof(u32));
-                       continue;
+                       goto free_fib;
                }
                /*
                 *      We will process the FIB here or pass it to a