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>
This commit is contained in:
parent
f6eb53498e
commit
a12af1ebe6
1 changed files with 2 additions and 2 deletions
|
@ -698,8 +698,8 @@ static int gfs2_flock(struct file *file, int cmd, struct file_lock *fl)
|
||||||
|
|
||||||
if (!(fl->fl_flags & FL_FLOCK))
|
if (!(fl->fl_flags & FL_FLOCK))
|
||||||
return -ENOLCK;
|
return -ENOLCK;
|
||||||
if (__mandatory_lock(&ip->i_inode))
|
if (fl->fl_type & LOCK_MAND)
|
||||||
return -ENOLCK;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
if (fl->fl_type == F_UNLCK) {
|
if (fl->fl_type == F_UNLCK) {
|
||||||
do_unflock(file, fl);
|
do_unflock(file, fl);
|
||||||
|
|
Loading…
Reference in a new issue