summaryrefslogtreecommitdiffstats
path: root/sys/kern/sys_generic.c
diff options
context:
space:
mode:
authoralfred <alfred@FreeBSD.org>2002-03-15 08:03:46 +0000
committeralfred <alfred@FreeBSD.org>2002-03-15 08:03:46 +0000
commitb0fd50345a3289e9bb8d558d427d688f80e93c0b (patch)
tree79b2481021420dbb65f469bde8de9f78a99e15a3 /sys/kern/sys_generic.c
parent2609492c806a011026054da1d551410de94ea04c (diff)
downloadFreeBSD-src-b0fd50345a3289e9bb8d558d427d688f80e93c0b.zip
FreeBSD-src-b0fd50345a3289e9bb8d558d427d688f80e93c0b.tar.gz
Giant pushdown for read/write/pread/pwrite syscalls.
kern/kern_descrip.c: Aquire Giant in fdrop_locked when file refcount hits zero, this removes the requirement for the caller to own Giant for the most part. kern/kern_ktrace.c: Aquire Giant in ktrgenio, simplifies locking in upper read/write syscalls. kern/vfs_bio.c: Aquire Giant in bwillwrite if needed. kern/sys_generic.c Giant pushdown, remove Giant for: read, pread, write and pwrite. readv and writev aren't done yet because of the possible malloc calls for iov to uio processing. kern/sys_socket.c Grab giant in the socket fo_read/write functions. kern/vfs_vnops.c Grab giant in the vnode fo_read/write functions.
Diffstat (limited to 'sys/kern/sys_generic.c')
-rw-r--r--sys/kern/sys_generic.c8
1 files changed, 0 insertions, 8 deletions
diff --git a/sys/kern/sys_generic.c b/sys/kern/sys_generic.c
index dff12a1..16fdcf8 100644
--- a/sys/kern/sys_generic.c
+++ b/sys/kern/sys_generic.c
@@ -102,13 +102,11 @@ read(td, uap)
struct file *fp;
int error;
- mtx_lock(&Giant);
if ((error = fget_read(td, uap->fd, &fp)) == 0) {
error = dofileread(td, fp, uap->fd, uap->buf,
uap->nbyte, (off_t)-1, 0);
fdrop(fp, td);
}
- mtx_unlock(&Giant);
return(error);
}
@@ -137,7 +135,6 @@ pread(td, uap)
if ((error = fget_read(td, uap->fd, &fp)) != 0)
return (error);
- mtx_lock(&Giant);
if (fp->f_type != DTYPE_VNODE) {
error = ESPIPE;
} else {
@@ -145,7 +142,6 @@ pread(td, uap)
uap->offset, FOF_OFFSET);
}
fdrop(fp, td);
- mtx_unlock(&Giant);
return(error);
}
@@ -332,7 +328,6 @@ write(td, uap)
struct file *fp;
int error;
- mtx_lock(&Giant);
if ((error = fget_write(td, uap->fd, &fp)) == 0) {
error = dofilewrite(td, fp, uap->fd, uap->buf, uap->nbyte,
(off_t)-1, 0);
@@ -340,7 +335,6 @@ write(td, uap)
} else {
error = EBADF; /* XXX this can't be right */
}
- mtx_unlock(&Giant);
return(error);
}
@@ -368,7 +362,6 @@ pwrite(td, uap)
int error;
if ((error = fget_write(td, uap->fd, &fp)) == 0) {
- mtx_lock(&Giant);
if (fp->f_type == DTYPE_VNODE) {
error = dofilewrite(td, fp, uap->fd, uap->buf,
uap->nbyte, uap->offset, FOF_OFFSET);
@@ -376,7 +369,6 @@ pwrite(td, uap)
error = ESPIPE;
}
fdrop(fp, td);
- mtx_unlock(&Giant);
} else {
error = EBADF; /* this can't be right */
}
OpenPOWER on IntegriCloud