Commit aba24d71 authored by Frank Filz's avatar Frank Filz Committed by J. Bruce Fields

nfsd: Fix sort_pacl in fs/nfsd/nf4acl.c to actually sort groups

We have been doing some extensive testing of Linux support for ACLs on
NFDS v4. We have noticed that the server rejects ACLs where the groups
are out of order, for example, the following ACL is rejected:

A::OWNER@:rwaxtTcCy
A::user101@domain:rwaxtcy
A::GROUP@:rwaxtcy
A:g:group102@domain:rwaxtcy
A:g:group101@domain:rwaxtcy
A::EVERYONE@:rwaxtcy

Examining the server code, I found that after converting an NFS v4 ACL
to POSIX, sort_pacl is called to sort the user ACEs and group ACEs.
Unfortunately, a minor bug causes the group sort to be skipped.
Signed-off-by: default avatarFrank Filz <ffilzlnx@us.ibm.com>
Signed-off-by: default avatarJ. Bruce Fields <bfields@citi.umich.edu>
parent dc83d6e2
...@@ -389,7 +389,7 @@ sort_pacl(struct posix_acl *pacl) ...@@ -389,7 +389,7 @@ sort_pacl(struct posix_acl *pacl)
sort_pacl_range(pacl, 1, i-1); sort_pacl_range(pacl, 1, i-1);
BUG_ON(pacl->a_entries[i].e_tag != ACL_GROUP_OBJ); BUG_ON(pacl->a_entries[i].e_tag != ACL_GROUP_OBJ);
j = i++; j = ++i;
while (pacl->a_entries[j].e_tag == ACL_GROUP) while (pacl->a_entries[j].e_tag == ACL_GROUP)
j++; j++;
sort_pacl_range(pacl, i, j-1); sort_pacl_range(pacl, i, j-1);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment