scsi: sg: factor out sg_fill_request_table()
Factor out sg_fill_request_table() for better readability. [mkp: typos, applied by hand] Signed-off-by: Hannes Reinecke <hare@suse.com> Reviewed-by: Bart Van Assche <bart.vanassche@wdc.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
parent
9c95be0163
commit
4759df905a
|
@ -828,6 +828,40 @@ static int max_sectors_bytes(struct request_queue *q)
|
||||||
return max_sectors << 9;
|
return max_sectors << 9;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
sg_fill_request_table(Sg_fd *sfp, sg_req_info_t *rinfo)
|
||||||
|
{
|
||||||
|
Sg_request *srp;
|
||||||
|
int val;
|
||||||
|
unsigned int ms;
|
||||||
|
|
||||||
|
val = 0;
|
||||||
|
list_for_each_entry(srp, &sfp->rq_list, entry) {
|
||||||
|
if (val > SG_MAX_QUEUE)
|
||||||
|
break;
|
||||||
|
memset(&rinfo[val], 0, SZ_SG_REQ_INFO);
|
||||||
|
rinfo[val].req_state = srp->done + 1;
|
||||||
|
rinfo[val].problem =
|
||||||
|
srp->header.masked_status &
|
||||||
|
srp->header.host_status &
|
||||||
|
srp->header.driver_status;
|
||||||
|
if (srp->done)
|
||||||
|
rinfo[val].duration =
|
||||||
|
srp->header.duration;
|
||||||
|
else {
|
||||||
|
ms = jiffies_to_msecs(jiffies);
|
||||||
|
rinfo[val].duration =
|
||||||
|
(ms > srp->header.duration) ?
|
||||||
|
(ms - srp->header.duration) : 0;
|
||||||
|
}
|
||||||
|
rinfo[val].orphan = srp->orphan;
|
||||||
|
rinfo[val].sg_io_owned = srp->sg_io_owned;
|
||||||
|
rinfo[val].pack_id = srp->header.pack_id;
|
||||||
|
rinfo[val].usr_ptr = srp->header.usr_ptr;
|
||||||
|
val++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static long
|
static long
|
||||||
sg_ioctl(struct file *filp, unsigned int cmd_in, unsigned long arg)
|
sg_ioctl(struct file *filp, unsigned int cmd_in, unsigned long arg)
|
||||||
{
|
{
|
||||||
|
@ -1012,38 +1046,13 @@ sg_ioctl(struct file *filp, unsigned int cmd_in, unsigned long arg)
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
else {
|
else {
|
||||||
sg_req_info_t *rinfo;
|
sg_req_info_t *rinfo;
|
||||||
unsigned int ms;
|
|
||||||
|
|
||||||
rinfo = kmalloc(SZ_SG_REQ_INFO * SG_MAX_QUEUE,
|
rinfo = kmalloc(SZ_SG_REQ_INFO * SG_MAX_QUEUE,
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
if (!rinfo)
|
if (!rinfo)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
read_lock_irqsave(&sfp->rq_list_lock, iflags);
|
read_lock_irqsave(&sfp->rq_list_lock, iflags);
|
||||||
val = 0;
|
sg_fill_request_table(sfp, rinfo);
|
||||||
list_for_each_entry(srp, &sfp->rq_list, entry) {
|
|
||||||
if (val >= SG_MAX_QUEUE)
|
|
||||||
break;
|
|
||||||
memset(&rinfo[val], 0, SZ_SG_REQ_INFO);
|
|
||||||
rinfo[val].req_state = srp->done + 1;
|
|
||||||
rinfo[val].problem =
|
|
||||||
srp->header.masked_status &
|
|
||||||
srp->header.host_status &
|
|
||||||
srp->header.driver_status;
|
|
||||||
if (srp->done)
|
|
||||||
rinfo[val].duration =
|
|
||||||
srp->header.duration;
|
|
||||||
else {
|
|
||||||
ms = jiffies_to_msecs(jiffies);
|
|
||||||
rinfo[val].duration =
|
|
||||||
(ms > srp->header.duration) ?
|
|
||||||
(ms - srp->header.duration) : 0;
|
|
||||||
}
|
|
||||||
rinfo[val].orphan = srp->orphan;
|
|
||||||
rinfo[val].sg_io_owned = srp->sg_io_owned;
|
|
||||||
rinfo[val].pack_id = srp->header.pack_id;
|
|
||||||
rinfo[val].usr_ptr = srp->header.usr_ptr;
|
|
||||||
val++;
|
|
||||||
}
|
|
||||||
read_unlock_irqrestore(&sfp->rq_list_lock, iflags);
|
read_unlock_irqrestore(&sfp->rq_list_lock, iflags);
|
||||||
result = __copy_to_user(p, rinfo,
|
result = __copy_to_user(p, rinfo,
|
||||||
SZ_SG_REQ_INFO * SG_MAX_QUEUE);
|
SZ_SG_REQ_INFO * SG_MAX_QUEUE);
|
||||||
|
|
Loading…
Reference in New Issue