aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/alpha/include/asm/fcntl.h2
-rw-r--r--fs/locks.c14
-rw-r--r--include/asm-generic/fcntl.h5
-rw-r--r--include/linux/fs.h3
4 files changed, 10 insertions, 14 deletions
diff --git a/arch/alpha/include/asm/fcntl.h b/arch/alpha/include/asm/fcntl.h
index 1b71ca70c9f6..6d9e805f18a7 100644
--- a/arch/alpha/include/asm/fcntl.h
+++ b/arch/alpha/include/asm/fcntl.h
@@ -51,8 +51,6 @@
51#define F_EXLCK 16 /* or 3 */ 51#define F_EXLCK 16 /* or 3 */
52#define F_SHLCK 32 /* or 4 */ 52#define F_SHLCK 32 /* or 4 */
53 53
54#define F_INPROGRESS 64
55
56#include <asm-generic/fcntl.h> 54#include <asm-generic/fcntl.h>
57 55
58#endif 56#endif
diff --git a/fs/locks.c b/fs/locks.c
index c528522862b1..c4215418bca3 100644
--- a/fs/locks.c
+++ b/fs/locks.c
@@ -135,7 +135,7 @@
135 135
136static bool lease_breaking(struct file_lock *fl) 136static bool lease_breaking(struct file_lock *fl)
137{ 137{
138 return fl->fl_type & F_INPROGRESS; 138 return fl->fl_flags & FL_INPROGRESS;
139} 139}
140 140
141int leases_enable = 1; 141int leases_enable = 1;
@@ -1132,6 +1132,7 @@ int lease_modify(struct file_lock **before, int arg)
1132 1132
1133 if (error) 1133 if (error)
1134 return error; 1134 return error;
1135 fl->fl_flags &= ~FL_INPROGRESS;
1135 locks_wake_up_blocks(fl); 1136 locks_wake_up_blocks(fl);
1136 if (arg == F_UNLCK) 1137 if (arg == F_UNLCK)
1137 locks_delete_lock(before); 1138 locks_delete_lock(before);
@@ -1152,7 +1153,7 @@ static void time_out_leases(struct inode *inode)
1152 before = &fl->fl_next; 1153 before = &fl->fl_next;
1153 continue; 1154 continue;
1154 } 1155 }
1155 lease_modify(before, fl->fl_type & ~F_INPROGRESS); 1156 lease_modify(before, fl->fl_type);
1156 if (fl == *before) /* lease_modify may have freed fl */ 1157 if (fl == *before) /* lease_modify may have freed fl */
1157 before = &fl->fl_next; 1158 before = &fl->fl_next;
1158 } 1159 }
@@ -1193,13 +1194,13 @@ int __break_lease(struct inode *inode, unsigned int mode)
1193 1194
1194 if (want_write) { 1195 if (want_write) {
1195 /* If we want write access, we have to revoke any lease. */ 1196 /* If we want write access, we have to revoke any lease. */
1196 future = F_UNLCK | F_INPROGRESS; 1197 future = F_UNLCK;
1197 } else if (lease_breaking(flock)) { 1198 } else if (lease_breaking(flock)) {
1198 /* If the lease is already being broken, we just leave it */ 1199 /* If the lease is already being broken, we just leave it */
1199 future = flock->fl_type; 1200 future = flock->fl_type;
1200 } else if (flock->fl_type & F_WRLCK) { 1201 } else if (flock->fl_type & F_WRLCK) {
1201 /* Downgrade the exclusive lease to a read-only lease. */ 1202 /* Downgrade the exclusive lease to a read-only lease. */
1202 future = F_RDLCK | F_INPROGRESS; 1203 future = F_RDLCK;
1203 } else { 1204 } else {
1204 /* the existing lease was read-only, so we can read too. */ 1205 /* the existing lease was read-only, so we can read too. */
1205 goto out; 1206 goto out;
@@ -1221,6 +1222,7 @@ int __break_lease(struct inode *inode, unsigned int mode)
1221 for (fl = flock; fl && IS_LEASE(fl); fl = fl->fl_next) { 1222 for (fl = flock; fl && IS_LEASE(fl); fl = fl->fl_next) {
1222 if (fl->fl_type != future) { 1223 if (fl->fl_type != future) {
1223 fl->fl_type = future; 1224 fl->fl_type = future;
1225 fl->fl_flags |= FL_INPROGRESS;
1224 fl->fl_break_time = break_time; 1226 fl->fl_break_time = break_time;
1225 /* lease must have lmops break callback */ 1227 /* lease must have lmops break callback */
1226 fl->fl_lmops->lm_break(fl); 1228 fl->fl_lmops->lm_break(fl);
@@ -1319,7 +1321,7 @@ int fcntl_getlease(struct file *filp)
1319 for (fl = filp->f_path.dentry->d_inode->i_flock; fl && IS_LEASE(fl); 1321 for (fl = filp->f_path.dentry->d_inode->i_flock; fl && IS_LEASE(fl);
1320 fl = fl->fl_next) { 1322 fl = fl->fl_next) {
1321 if (fl->fl_file == filp) { 1323 if (fl->fl_file == filp) {
1322 type = fl->fl_type & ~F_INPROGRESS; 1324 type = fl->fl_type;
1323 break; 1325 break;
1324 } 1326 }
1325 } 1327 }
@@ -1384,7 +1386,7 @@ int generic_setlease(struct file *filp, long arg, struct file_lock **flp)
1384 before = &fl->fl_next) { 1386 before = &fl->fl_next) {
1385 if (fl->fl_file == filp) 1387 if (fl->fl_file == filp)
1386 my_before = before; 1388 my_before = before;
1387 else if (fl->fl_type == (F_INPROGRESS | F_UNLCK)) 1389 else if ((fl->fl_type == F_UNLCK) && lease_breaking(fl))
1388 /* 1390 /*
1389 * Someone is in the process of opening this 1391 * Someone is in the process of opening this
1390 * file for writing so we may not take an 1392 * file for writing so we may not take an
diff --git a/include/asm-generic/fcntl.h b/include/asm-generic/fcntl.h
index 84793c7025e2..9e5b0356e2bb 100644
--- a/include/asm-generic/fcntl.h
+++ b/include/asm-generic/fcntl.h
@@ -145,11 +145,6 @@ struct f_owner_ex {
145#define F_SHLCK 8 /* or 4 */ 145#define F_SHLCK 8 /* or 4 */
146#endif 146#endif
147 147
148/* for leases */
149#ifndef F_INPROGRESS
150#define F_INPROGRESS 16
151#endif
152
153/* operations for bsd flock(), also used by the kernel implementation */ 148/* operations for bsd flock(), also used by the kernel implementation */
154#define LOCK_SH 1 /* shared lock */ 149#define LOCK_SH 1 /* shared lock */
155#define LOCK_EX 2 /* exclusive lock */ 150#define LOCK_EX 2 /* exclusive lock */
diff --git a/include/linux/fs.h b/include/linux/fs.h
index 178cdb4f1d4a..327fdd4de85f 100644
--- a/include/linux/fs.h
+++ b/include/linux/fs.h
@@ -1065,6 +1065,7 @@ static inline int file_check_writeable(struct file *filp)
1065#define FL_LEASE 32 /* lease held on this file */ 1065#define FL_LEASE 32 /* lease held on this file */
1066#define FL_CLOSE 64 /* unlock on close */ 1066#define FL_CLOSE 64 /* unlock on close */
1067#define FL_SLEEP 128 /* A blocking lock */ 1067#define FL_SLEEP 128 /* A blocking lock */
1068#define FL_INPROGRESS 256 /* Lease is being broken */
1068 1069
1069/* 1070/*
1070 * Special return value from posix_lock_file() and vfs_lock_file() for 1071 * Special return value from posix_lock_file() and vfs_lock_file() for
@@ -1111,7 +1112,7 @@ struct file_lock {
1111 struct list_head fl_link; /* doubly linked list of all locks */ 1112 struct list_head fl_link; /* doubly linked list of all locks */
1112 struct list_head fl_block; /* circular list of blocked processes */ 1113 struct list_head fl_block; /* circular list of blocked processes */
1113 fl_owner_t fl_owner; 1114 fl_owner_t fl_owner;
1114 unsigned char fl_flags; 1115 unsigned int fl_flags;
1115 unsigned char fl_type; 1116 unsigned char fl_type;
1116 unsigned int fl_pid; 1117 unsigned int fl_pid;
1117 struct pid *fl_nspid; 1118 struct pid *fl_nspid;