[GFS2] Fix attributes setting logic

The attributes logic for immutable was wrong so that there was
not way to remove this attribute once set. This fixes the
bug.

Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
diff --git a/fs/gfs2/ops_file.c b/fs/gfs2/ops_file.c
index c2dbc30..cf72480 100644
--- a/fs/gfs2/ops_file.c
+++ b/fs/gfs2/ops_file.c
@@ -611,8 +611,10 @@
 
 	gfs2_holder_init(ip->i_gl, LM_ST_EXCLUSIVE, 0, &gh);
 	error = gfs2_glock_nq_init(ip->i_gl, LM_ST_EXCLUSIVE, 0, &gh);
-	if (error)
+	if (error) {
+		gfs2_holder_uninit(&gh);
 		return error;
+	}
 
 	flags = ip->i_di.di_flags;
 	new_flags = (flags & ~mask) | (reqflags & mask);
@@ -635,9 +637,14 @@
 		goto out;
 	if (IS_APPEND(inode) && (new_flags & GFS2_DIF_APPENDONLY))
 		goto out;
-	error = gfs2_repermission(inode, MAY_WRITE, NULL);
-	if (error)
+	if (((new_flags ^ flags) & GFS2_DIF_IMMUTABLE) && 
+	    !capable(CAP_LINUX_IMMUTABLE))
 		goto out;
+	if (!IS_IMMUTABLE(inode)) {
+		error = gfs2_repermission(inode, MAY_WRITE, NULL);
+		if (error)
+			goto out;
+	}
 
 	error = gfs2_trans_begin(sdp, RES_DINODE, 0);
 	if (error)