1. NAME

blk_queue_start_tag - find a free tag and assign it

2. SYNOPSIS

int blk_queue_start_tag(struct request_queue *  q , struct request *  rq );

3. ARGUMENTS

q
    the request queue for the device

rq
    the block request that needs tagging

4. DESCRIPTION

This can either be used as a stand-alone helper, or possibly be assigned as the queue prep_rq_fn (in which case struct request automagically gets a tag assigned). Note that this function assumes that any type of request can be queued! if this is not true for your device, you must check the request type before calling this function. The request will also be removed from the request queue, so itAqs the drivers responsibility to readd it if it should need to be restarted for some reason.

5. NOTES

queue lock must be held.

6. COPYRIGHT