mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	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
					
				
					 1 changed files with 35 additions and 26 deletions
				
			
		| 
						 | 
					@ -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 a new issue