Hi Bart

Thanks for your kindly response.

On 02/27/2018 11:41 AM, Bart Van Assche wrote:
> On Tue, 2018-02-27 at 11:28 +0800, jianchao.wang wrote:
>> If that is true, what if aacraid driver uses block legacy instead of blk-mq ?
>> w/ blk-mq disabled, __scsi_queue_insert just requeue the request with 
>> blk_requeue_request.
>>
>> __scsi_queue_insert
>> ...
>>      if (q->mq_ops) {
>>              scsi_mq_requeue_cmd(cmd);
>>              return;
>>      }
>>      spin_lock_irqsave(q->queue_lock, flags);
>>      blk_requeue_request(q, cmd->request);
>>      kblockd_schedule_work(&device->requeue_work);
>>      spin_unlock_irqrestore(q->queue_lock, flags);
>> ...
>>
>> no prep/unprep code there for block legacy code.
> 
> Hello Jianchao,
> 
> For the legacy block layer preparing and unpreparing a request happens from
> inside the block layer core. Please have a look at block/blk-core.c and the
> code in that file that handles the request flag RQF_DONTPREP.
Yes, thanks for your directive.

On the other hand, this patch is to align the actions between blk-mq and block 
legacy code in __scsi_queue_insert.
As we know, __scsi_queue_insert is just to requeue the request back to queue, 
as the block legacy code segment above:
for block legacy, it just blk_requeue_request for the request and kick the 
queue run.
However, for the blk-mq, scsi_mq_requeue_cmd will be invoked, it not only 
requeue the request, but also unprep request.
This is not what __scsi_queue_insert should do, but scsi_io_completion.
When the request is not finished completely, and scsi_io_completion finds it 
need a ACTION_REPREP, at the moment,
we need requeue and unprep there.

If I missed something, please feel free to point out. :)

Thanks
Jianchao

 

> 
> Thanks,
> 
> Bart.
> 
> 
> 

Reply via email to