aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthew Wilcox <matthew@wil.cx>2007-09-09 10:56:35 -0400
committerJames Bottomley <jejb@mulgrave.localdomain>2007-10-12 14:47:59 -0400
commitb2a7a4ba0497f73295e3f4d20a8cedb1e3d2b1a7 (patch)
tree933be186e56c83dced0c04e6f30eb2ad0e3999fb
parent349d2c44291d922614a273e9a4e6b43ee17c103d (diff)
[SCSI] advansys: Enable interrupts earlier in queuecommand
Move as much as possible outside the critical section in queuecommand, eg: - Set the scsi_done field before acquiring the lock - Call asc_scsi_done after dropping the lock Also remove a comment suggesting we should enable interrupts (now we do) and do some minor reformatting for readability. Signed-off-by: Matthew Wilcox <matthew@wil.cx> Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
-rw-r--r--drivers/scsi/advansys.c23
1 files changed, 11 insertions, 12 deletions
diff --git a/drivers/scsi/advansys.c b/drivers/scsi/advansys.c
index 67cdfe6201ce..d7bc0cf72134 100644
--- a/drivers/scsi/advansys.c
+++ b/drivers/scsi/advansys.c
@@ -3176,23 +3176,24 @@ static void asc_scsi_done(struct scsi_cmnd *scp)
3176 * in the 'scp' result field. 3176 * in the 'scp' result field.
3177 */ 3177 */
3178static int 3178static int
3179advansys_queuecommand(struct scsi_cmnd *scp, void (*done) (struct scsi_cmnd *)) 3179advansys_queuecommand(struct scsi_cmnd *scp, void (*done)(struct scsi_cmnd *))
3180{ 3180{
3181 struct Scsi_Host *shost; 3181 struct Scsi_Host *shost = scp->device->host;
3182 asc_board_t *boardp; 3182 asc_board_t *boardp = ASC_BOARDP(shost);
3183 ulong flags; 3183 unsigned long flags;
3184 int asc_res, result = 0; 3184 int asc_res, result = 0;
3185 3185
3186 shost = scp->device->host;
3187 boardp = ASC_BOARDP(shost);
3188 ASC_STATS(shost, queuecommand); 3186 ASC_STATS(shost, queuecommand);
3187 scp->scsi_done = done;
3189 3188
3190 /* host_lock taken by mid-level prior to call but need to protect */ 3189 /*
3191 /* against own ISR */ 3190 * host_lock taken by mid-level prior to call, but need
3191 * to protect against own ISR
3192 */
3192 spin_lock_irqsave(&boardp->lock, flags); 3193 spin_lock_irqsave(&boardp->lock, flags);
3193
3194 scp->scsi_done = done;
3195 asc_res = asc_execute_scsi_cmnd(scp); 3194 asc_res = asc_execute_scsi_cmnd(scp);
3195 spin_unlock_irqrestore(&boardp->lock, flags);
3196
3196 switch (asc_res) { 3197 switch (asc_res) {
3197 case ASC_NOERROR: 3198 case ASC_NOERROR:
3198 break; 3199 break;
@@ -3201,11 +3202,9 @@ advansys_queuecommand(struct scsi_cmnd *scp, void (*done) (struct scsi_cmnd *))
3201 break; 3202 break;
3202 case ASC_ERROR: 3203 case ASC_ERROR:
3203 default: 3204 default:
3204 /* Interrupts could be enabled here. */
3205 asc_scsi_done(scp); 3205 asc_scsi_done(scp);
3206 break; 3206 break;
3207 } 3207 }
3208 spin_unlock_irqrestore(&boardp->lock, flags);
3209 3208
3210 return result; 3209 return result;
3211} 3210}