summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/kern/vfs_lockf.c71
1 files changed, 11 insertions, 60 deletions
diff --git a/sys/kern/vfs_lockf.c b/sys/kern/vfs_lockf.c
index a67eaa4d2f2..a02015ec28e 100644
--- a/sys/kern/vfs_lockf.c
+++ b/sys/kern/vfs_lockf.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: vfs_lockf.c,v 1.15 2009/03/24 09:04:30 otto Exp $ */
+/* $OpenBSD: vfs_lockf.c,v 1.16 2010/06/29 03:14:42 tedu Exp $ */
/* $NetBSD: vfs_lockf.c,v 1.7 1996/02/04 02:18:21 christos Exp $ */
/*
@@ -141,7 +141,6 @@ lf_advlock(struct lockf **head, off_t size, caddr_t id, int op,
* Convert the flock structure into a start and end.
*/
switch (fl->l_whence) {
-
case SEEK_SET:
case SEEK_CUR:
/*
@@ -150,19 +149,17 @@ lf_advlock(struct lockf **head, off_t size, caddr_t id, int op,
*/
start = fl->l_start;
break;
-
case SEEK_END:
start = size + fl->l_start;
break;
-
default:
return (EINVAL);
}
if (start < 0)
return (EINVAL);
- if (fl->l_len == 0)
+ if (fl->l_len == 0) {
end = -1;
- else {
+ } else {
end = start + fl->l_len - 1;
if (end < start)
return (EINVAL);
@@ -178,9 +175,6 @@ lf_advlock(struct lockf **head, off_t size, caddr_t id, int op,
}
}
- /*
- * Create the lockf structure.
- */
lock = lf_alloc(p->p_ucred->cr_uid, op == F_SETLK ? 1 : 2);
if (!lock)
return (ENOLCK);
@@ -193,24 +187,18 @@ lf_advlock(struct lockf **head, off_t size, caddr_t id, int op,
TAILQ_INIT(&lock->lf_blkhd);
lock->lf_flags = flags;
lock->lf_pid = (flags & F_POSIX) ? curproc->p_pid : -1;
- /*
- * Do the requested operation.
- */
- switch (op) {
+ switch (op) {
case F_SETLK:
return (lf_setlock(lock));
-
case F_UNLCK:
error = lf_clearlock(lock);
lf_free(lock);
return (error);
-
case F_GETLK:
error = lf_getlock(lock, fl);
lf_free(lock);
return (error);
-
default:
lf_free(lock);
return (EINVAL);
@@ -235,9 +223,6 @@ lf_setlock(struct lockf *lock)
lf_print("lf_setlock", lock);
#endif /* LOCKF_DEBUG */
- /*
- * Set the priority
- */
priority = PLOCK;
if (lock->lf_type == F_WRLCK)
priority += 4;
@@ -246,9 +231,6 @@ lf_setlock(struct lockf *lock)
* Scan lock list for this file looking for locks that would block us.
*/
while ((block = lf_getblock(lock)) != NULL) {
- /*
- * Free the structure and return if nonblocking.
- */
if ((lock->lf_flags & F_WAIT) == 0) {
lf_free(lock);
return (EAGAIN);
@@ -291,10 +273,9 @@ lf_setlock(struct lockf *lock)
* any shared locks that we hold before we sleep
* waiting for an exclusive lock.
*/
- if ((lock->lf_flags & F_FLOCK) &&
- lock->lf_type == F_WRLCK) {
+ if ((lock->lf_flags & F_FLOCK) && lock->lf_type == F_WRLCK) {
lock->lf_type = F_UNLCK;
- (void) lf_clearlock(lock);
+ (void)lf_clearlock(lock);
lock->lf_type = F_WRLCK;
}
/*
@@ -310,16 +291,6 @@ lf_setlock(struct lockf *lock)
#endif /* LOCKF_DEBUG */
TAILQ_INSERT_TAIL(&block->lf_blkhd, lock, lf_block);
error = tsleep(lock, priority, lockstr, 0);
-#if 0
- if (error) {
- /*
- * Delete ourselves from the waiting to lock list.
- */
- TAILQ_REMOVE(&lock->lf_next->lf_blkhd, lock, lf_block);
- lf_free(lock);
- return (error);
- }
-#else
if (lock->lf_next != NULL) {
TAILQ_REMOVE(&lock->lf_next->lf_blkhd, lock, lf_block);
lock->lf_next = NULL;
@@ -328,7 +299,6 @@ lf_setlock(struct lockf *lock)
lf_free(lock);
return (error);
}
-#endif
}
/*
* No blocks!! Add the lock. Note that we will
@@ -361,7 +331,6 @@ lf_setlock(struct lockf *lock)
lock->lf_next = overlap;
}
break;
-
case 1: /* overlap == lock */
/*
* If downgrading lock, others may be
@@ -374,7 +343,6 @@ lf_setlock(struct lockf *lock)
lf_free(lock);
lock = overlap; /* for debug output below */
break;
-
case 2: /* overlap contains lock */
/*
* Check for common starting point and different types.
@@ -392,7 +360,6 @@ lf_setlock(struct lockf *lock)
lf_split(overlap, lock);
lf_wakelock(overlap);
break;
-
case 3: /* lock contains overlap */
/*
* If downgrading lock, others may be able to
@@ -423,7 +390,6 @@ lf_setlock(struct lockf *lock)
*prev = overlap->lf_next;
lf_free(overlap);
continue;
-
case 4: /* overlap starts before lock */
/*
* Add lock after overlap on the list.
@@ -435,7 +401,6 @@ lf_setlock(struct lockf *lock)
lf_wakelock(overlap);
needtolink = 0;
continue;
-
case 5: /* overlap ends after lock */
/*
* Add the new lock before overlap.
@@ -479,20 +444,14 @@ lf_clearlock(struct lockf *lock)
lf_print("lf_clearlock", lock);
#endif /* LOCKF_DEBUG */
prev = head;
- while ((ovcase = lf_findoverlap(lf, lock, SELF,
- &prev, &overlap)) != 0) {
- /*
- * Wakeup the list of locks to be retried.
- */
+ while ((ovcase = lf_findoverlap(lf, lock, SELF, &prev, &overlap))) {
lf_wakelock(overlap);
switch (ovcase) {
-
case 1: /* overlap == lock */
*prev = overlap->lf_next;
lf_free(overlap);
break;
-
case 2: /* overlap contains lock: split it */
if (overlap->lf_start == lock->lf_start) {
overlap->lf_start = lock->lf_end + 1;
@@ -501,19 +460,16 @@ lf_clearlock(struct lockf *lock)
lf_split(overlap, lock);
overlap->lf_next = lock->lf_next;
break;
-
case 3: /* lock contains overlap */
*prev = overlap->lf_next;
lf = overlap->lf_next;
lf_free(overlap);
continue;
-
case 4: /* overlap starts before lock */
overlap->lf_end = lock->lf_start - 1;
prev = &overlap->lf_next;
lf = overlap->lf_next;
continue;
-
case 5: /* overlap ends after lock */
overlap->lf_start = lock->lf_end + 1;
break;
@@ -639,15 +595,13 @@ lf_findoverlap(struct lockf *lf, struct lockf *lock, int type,
}
/* Case 2 */
if ((lf->lf_start <= start) &&
- (lf->lf_end == -1 ||
- (end != -1 && lf->lf_end >= end))) {
+ (lf->lf_end == -1 || (end != -1 && lf->lf_end >= end))) {
DPRINTF(("overlap contains lock\n"), DEBUG_FINDOVR);
return (2);
}
/* Case 3 */
if (start <= lf->lf_start &&
- (end == -1 ||
- (lf->lf_end != -1 && end >= lf->lf_end))) {
+ (end == -1 || (lf->lf_end != -1 && end >= lf->lf_end))) {
DPRINTF(("lock contains overlap\n"), DEBUG_FINDOVR);
return (3);
}
@@ -659,8 +613,7 @@ lf_findoverlap(struct lockf *lf, struct lockf *lock, int type,
return (4);
}
/* Case 5 */
- if ((lf->lf_start > start) &&
- (end != -1) &&
+ if ((lf->lf_start > start) && (end != -1) &&
((lf->lf_end > end) || (lf->lf_end == -1))) {
DPRINTF(("overlap ends after lock\n"), DEBUG_FINDOVR);
return (5);
@@ -709,9 +662,7 @@ lf_split(struct lockf *lock1, struct lockf *lock2)
splitlock->lf_block.tqe_next = NULL;
TAILQ_INIT(&splitlock->lf_blkhd);
lock1->lf_end = lock2->lf_start - 1;
- /*
- * OK, now link it in
- */
+
lock2->lf_next = splitlock;
lock1->lf_next = lock2;
}