diff options
author | dg <dg@FreeBSD.org> | 1993-11-25 06:30:58 +0000 |
---|---|---|
committer | dg <dg@FreeBSD.org> | 1993-11-25 06:30:58 +0000 |
commit | 1d18814c411964364107261ef59f1deb6b793e58 (patch) | |
tree | f01ed7ee8ad68574f1f927bba57e2d5bab37b7c3 /sys/scsi | |
parent | 8e24073a9b2dcc5fd2bcd719dd679f029d4818cb (diff) | |
download | FreeBSD-src-1d18814c411964364107261ef59f1deb6b793e58.zip FreeBSD-src-1d18814c411964364107261ef59f1deb6b793e58.tar.gz |
Patch from Julian Elischer:
Here is the fix for the 'hanging' bug.
This bug happenned whenever two operations were already underway on the
disk and a third (non-IO) command was requested..
in this case the process submitting the NON-IO command was requested to wait,
and a flag set so that on completion of the IO commands, the Non-io command
was given priority over any pending IO commands. (the queue is not
allowed to drain while there are pending "special" ops).
The flag that indicated this was not being reset, so further IO commands
were prohibited from that moment on.
Diffstat (limited to 'sys/scsi')
-rw-r--r-- | sys/scsi/scsi_base.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/sys/scsi/scsi_base.c b/sys/scsi/scsi_base.c index a1361ec..da9c2b4 100644 --- a/sys/scsi/scsi_base.c +++ b/sys/scsi/scsi_base.c @@ -8,7 +8,7 @@ * file. * * Written by Julian Elischer (julian@dialix.oz.au) - * $Id: scsi_base.c,v 2.4 93/10/16 00:58:43 julian Exp Locker: julian $ + * $Id: scsi_base.c,v 1.1 1993/11/18 05:02:51 rgrimes Exp $ */ #define SPLSD splbio @@ -109,7 +109,8 @@ free_xs(xs, sc_link, flags) SC_DEBUG(sc_link, SDEV_DB3, ("free_xs\n")); /* if was 0 and someone waits, wake them up */ if ((!sc_link->opennings++) && (sc_link->flags & SDEV_WAITING)) { - wakeup(sc_link); + sc_link->flags &= ~SDEV_WAITING; + wakeup(sc_link); /* remember, it wakes them ALL up */ } else { if (sc_link->device->start) { SC_DEBUG(sc_link, SDEV_DB2, ("calling private start()\n")); |