|
@@ -2030,12 +2030,9 @@ extern struct kobject *fs_kobj;
|
|
|
|
|
|
#define MAX_RW_COUNT (INT_MAX & PAGE_CACHE_MASK)
|
|
|
|
|
|
-#define FLOCK_VERIFY_READ 1
|
|
|
-#define FLOCK_VERIFY_WRITE 2
|
|
|
-
|
|
|
#ifdef CONFIG_FILE_LOCKING
|
|
|
extern int locks_mandatory_locked(struct file *);
|
|
|
-extern int locks_mandatory_area(int, struct inode *, struct file *, loff_t, size_t);
|
|
|
+extern int locks_mandatory_area(struct inode *, struct file *, loff_t, loff_t, unsigned char);
|
|
|
|
|
|
/*
|
|
|
* Candidates for mandatory locking have the setgid bit set
|
|
@@ -2065,17 +2062,19 @@ static inline int locks_verify_locked(struct file *file)
|
|
|
}
|
|
|
|
|
|
static inline int locks_verify_truncate(struct inode *inode,
|
|
|
- struct file *filp,
|
|
|
+ struct file *f,
|
|
|
loff_t size)
|
|
|
{
|
|
|
- if (inode->i_flctx && mandatory_lock(inode))
|
|
|
- return locks_mandatory_area(
|
|
|
- FLOCK_VERIFY_WRITE, inode, filp,
|
|
|
- size < inode->i_size ? size : inode->i_size,
|
|
|
- (size < inode->i_size ? inode->i_size - size
|
|
|
- : size - inode->i_size)
|
|
|
- );
|
|
|
- return 0;
|
|
|
+ if (!inode->i_flctx || !mandatory_lock(inode))
|
|
|
+ return 0;
|
|
|
+
|
|
|
+ if (size < inode->i_size) {
|
|
|
+ return locks_mandatory_area(inode, f, size, inode->i_size - 1,
|
|
|
+ F_WRLCK);
|
|
|
+ } else {
|
|
|
+ return locks_mandatory_area(inode, f, inode->i_size, size - 1,
|
|
|
+ F_WRLCK);
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
static inline int break_lease(struct inode *inode, unsigned int mode)
|
|
@@ -2144,9 +2143,8 @@ static inline int locks_mandatory_locked(struct file *file)
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
-static inline int locks_mandatory_area(int rw, struct inode *inode,
|
|
|
- struct file *filp, loff_t offset,
|
|
|
- size_t count)
|
|
|
+static inline int locks_mandatory_area(struct inode *inode, struct file *filp,
|
|
|
+ loff_t start, loff_t end, unsigned char type)
|
|
|
{
|
|
|
return 0;
|
|
|
}
|