Remove Giant acquisition around soreceive() and sosend() in fifofs. The
bug that caused us to reintroduce it is believed to be fixed, and Kris says he no longer sees problems with fifofs in highly parallel builds. If this works out, we'll MFC it for 7.1. MFC after: 3 months Pointed out by: kris
This commit is contained in:
parent
3b9401db6f
commit
c55376e791
@ -705,17 +705,14 @@ static int
|
|||||||
fifo_read_f(struct file *fp, struct uio *uio, struct ucred *cred, int flags, struct thread *td)
|
fifo_read_f(struct file *fp, struct uio *uio, struct ucred *cred, int flags, struct thread *td)
|
||||||
{
|
{
|
||||||
struct fifoinfo *fip;
|
struct fifoinfo *fip;
|
||||||
int error, sflags;
|
int sflags;
|
||||||
|
|
||||||
fip = fp->f_data;
|
fip = fp->f_data;
|
||||||
KASSERT(uio->uio_rw == UIO_READ,("fifo_read mode"));
|
KASSERT(uio->uio_rw == UIO_READ,("fifo_read mode"));
|
||||||
if (uio->uio_resid == 0)
|
if (uio->uio_resid == 0)
|
||||||
return (0);
|
return (0);
|
||||||
sflags = (fp->f_flag & FNONBLOCK) ? MSG_NBIO : 0;
|
sflags = (fp->f_flag & FNONBLOCK) ? MSG_NBIO : 0;
|
||||||
mtx_lock(&Giant);
|
return (soreceive(fip->fi_readsock, NULL, uio, NULL, NULL, &sflags));
|
||||||
error = soreceive(fip->fi_readsock, NULL, uio, NULL, NULL, &sflags);
|
|
||||||
mtx_unlock(&Giant);
|
|
||||||
return (error);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@ -736,13 +733,10 @@ static int
|
|||||||
fifo_write_f(struct file *fp, struct uio *uio, struct ucred *cred, int flags, struct thread *td)
|
fifo_write_f(struct file *fp, struct uio *uio, struct ucred *cred, int flags, struct thread *td)
|
||||||
{
|
{
|
||||||
struct fifoinfo *fip;
|
struct fifoinfo *fip;
|
||||||
int error, sflags;
|
int sflags;
|
||||||
|
|
||||||
fip = fp->f_data;
|
fip = fp->f_data;
|
||||||
KASSERT(uio->uio_rw == UIO_WRITE,("fifo_write mode"));
|
KASSERT(uio->uio_rw == UIO_WRITE,("fifo_write mode"));
|
||||||
sflags = (fp->f_flag & FNONBLOCK) ? MSG_NBIO : 0;
|
sflags = (fp->f_flag & FNONBLOCK) ? MSG_NBIO : 0;
|
||||||
mtx_lock(&Giant);
|
return (sosend(fip->fi_writesock, NULL, uio, 0, NULL, sflags, td));
|
||||||
error = sosend(fip->fi_writesock, NULL, uio, 0, NULL, sflags, td);
|
|
||||||
mtx_unlock(&Giant);
|
|
||||||
return (error);
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user