Commit 794c10fa authored by Jörn Engel's avatar Jörn Engel Committed by James Bottomley

[SCSI] sg: remove while (1) non-loop

The while (1) construct isn't actually a loop at all.  So let's not
pretent and obfuscate the code.
Signed-off-by: default avatarJoern Engel <joern@logfs.org>
Acked-by: default avatarDouglas Gilbert <dgilbert@interlog.com>
Signed-off-by: default avatarJames Bottomley <JBottomley@Parallels.com>
parent dddbf8d9
...@@ -398,19 +398,15 @@ sg_read(struct file *filp, char __user *buf, size_t count, loff_t * ppos) ...@@ -398,19 +398,15 @@ sg_read(struct file *filp, char __user *buf, size_t count, loff_t * ppos)
retval = -EAGAIN; retval = -EAGAIN;
goto free_old_hdr; goto free_old_hdr;
} }
while (1) { retval = 0; /* following macro beats race condition */
retval = 0; /* following macro beats race condition */ __wait_event_interruptible(sfp->read_wait,
__wait_event_interruptible(sfp->read_wait, (sdp->detached ||
(sdp->detached || (srp = sg_get_rq_mark(sfp, req_pack_id))), retval);
(srp = sg_get_rq_mark(sfp, req_pack_id))), if (sdp->detached) {
retval); retval = -ENODEV;
if (sdp->detached) { goto free_old_hdr;
retval = -ENODEV; }
goto free_old_hdr; if (retval) {
}
if (0 == retval)
break;
/* -ERESTARTSYS as signal hit process */ /* -ERESTARTSYS as signal hit process */
goto free_old_hdr; goto free_old_hdr;
} }
...@@ -801,25 +797,21 @@ sg_ioctl(struct file *filp, unsigned int cmd_in, unsigned long arg) ...@@ -801,25 +797,21 @@ sg_ioctl(struct file *filp, unsigned int cmd_in, unsigned long arg)
1, read_only, 1, &srp); 1, read_only, 1, &srp);
if (result < 0) if (result < 0)
return result; return result;
while (1) { result = 0; /* following macro to beat race condition */
result = 0; /* following macro to beat race condition */ __wait_event_interruptible(sfp->read_wait,
__wait_event_interruptible(sfp->read_wait, (srp->done || sdp->detached), result);
(srp->done || sdp->detached), if (sdp->detached)
result); return -ENODEV;
if (sdp->detached) write_lock_irq(&sfp->rq_list_lock);
return -ENODEV; if (srp->done) {
write_lock_irq(&sfp->rq_list_lock); srp->done = 2;
if (srp->done) {
srp->done = 2;
write_unlock_irq(&sfp->rq_list_lock);
break;
}
srp->orphan = 1;
write_unlock_irq(&sfp->rq_list_lock); write_unlock_irq(&sfp->rq_list_lock);
return result; /* -ERESTARTSYS because signal hit process */ result = sg_new_read(sfp, p, SZ_SG_IO_HDR, srp);
return (result < 0) ? result : 0;
} }
result = sg_new_read(sfp, p, SZ_SG_IO_HDR, srp); srp->orphan = 1;
return (result < 0) ? result : 0; write_unlock_irq(&sfp->rq_list_lock);
return result; /* -ERESTARTSYS because signal hit process */
case SG_SET_TIMEOUT: case SG_SET_TIMEOUT:
result = get_user(val, ip); result = get_user(val, ip);
if (result) if (result)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment