diff options
author | Abhijith Das <adas@redhat.com> | 2009-06-01 13:30:03 -0400 |
---|---|---|
committer | Steven Whitehouse <swhiteho@redhat.com> | 2009-06-02 03:01:12 -0400 |
commit | a12af1ebe675e85831fde3c4d0908fc3b0908b7a (patch) | |
tree | ae03ea46bfa57031ee561f21d6e387fcdd7c46c7 /fs | |
parent | f6eb53498ee8f725832f3a0fffca90566bb118a6 (diff) |
GFS2: smbd proccess hangs with flock() call.
GFS2 currently does not support mandatory flocks. An flock() call with
LOCK_MAND triggers unexpected behavior because gfs2 is not checking for
this lock type. This patch corrects that.
Signed-off-by: Abhi Das <adas@redhat.com>
Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/gfs2/file.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/fs/gfs2/file.c b/fs/gfs2/file.c index 73b6f552f06d..841ddc979388 100644 --- a/fs/gfs2/file.c +++ b/fs/gfs2/file.c | |||
@@ -698,8 +698,8 @@ static int gfs2_flock(struct file *file, int cmd, struct file_lock *fl) | |||
698 | 698 | ||
699 | if (!(fl->fl_flags & FL_FLOCK)) | 699 | if (!(fl->fl_flags & FL_FLOCK)) |
700 | return -ENOLCK; | 700 | return -ENOLCK; |
701 | if (__mandatory_lock(&ip->i_inode)) | 701 | if (fl->fl_type & LOCK_MAND) |
702 | return -ENOLCK; | 702 | return -EOPNOTSUPP; |
703 | 703 | ||
704 | if (fl->fl_type == F_UNLCK) { | 704 | if (fl->fl_type == F_UNLCK) { |
705 | do_unflock(file, fl); | 705 | do_unflock(file, fl); |