cifs: avoid extra allocation for small cifs.idmap keys
authorJeff Layton <jlayton@redhat.com>
Mon, 3 Dec 2012 11:05:29 +0000 (06:05 -0500)
committerSteve French <smfrench@gmail.com>
Sun, 9 Dec 2012 04:04:28 +0000 (22:04 -0600)
commit41a9f1f6b38664fc08431674d87871a57d763be1
tree72c311410a7b5175776385f7a4947d4e77ac5d3c
parentfaa65f07d21e7d37190c91fdcf9f940d733ae3cc
cifs: avoid extra allocation for small cifs.idmap keys

The cifs.idmap keytype always allocates memory to hold the payload from
userspace. In the common case where we're translating a SID to a UID or
GID, we're allocating memory to hold something that's less than or equal
to the size of a pointer.

When the payload is the same size as a pointer or smaller, just store
it in the payload.value union member instead. That saves us an extra
allocation on the sid_to_id upcall.

Note that we have to take extra care to check the datalen when we
go to dereference the .data pointer in the union, but the callers
now check that as a matter of course anyway.

Reviewed-by: Shirish Pargaonkar <shirishpargaonkar@gmail.com>
Signed-off-by: Jeff Layton <jlayton@redhat.com>
Signed-off-by: Steve French <smfrench@gmail.com>
fs/cifs/cifsacl.c