|
Dave Jones |
bf89f3a |
diff -up linux-3.2.noarch/fs/nfs/idmap.c.orig linux-3.2.noarch/fs/nfs/idmap.c
|
|
Dave Jones |
bf89f3a |
--- linux-3.2.noarch/fs/nfs/idmap.c.orig 2012-03-14 13:08:37.462928792 -0400
|
|
Dave Jones |
bf89f3a |
+++ linux-3.2.noarch/fs/nfs/idmap.c 2012-03-14 13:10:17.076030982 -0400
|
|
Dave Jones |
bf89f3a |
@@ -365,7 +365,7 @@ struct idmap_hashent {
|
|
Dave Jones |
bf89f3a |
|
|
Dave Jones |
bf89f3a |
struct idmap_hashtable {
|
|
Dave Jones |
bf89f3a |
__u8 h_type;
|
|
Dave Jones |
bf89f3a |
- struct idmap_hashent h_entries[IDMAP_HASH_SZ];
|
|
Dave Jones |
bf89f3a |
+ struct idmap_hashent *h_entries;
|
|
Dave Jones |
bf89f3a |
};
|
|
Dave Jones |
bf89f3a |
|
|
Dave Jones |
bf89f3a |
struct idmap {
|
|
Dave Jones |
bf89f3a |
@@ -420,20 +420,39 @@ nfs_idmap_new(struct nfs_client *clp)
|
|
Dave Jones |
bf89f3a |
return 0;
|
|
Dave Jones |
bf89f3a |
}
|
|
Dave Jones |
bf89f3a |
|
|
Dave Jones |
bf89f3a |
+static void
|
|
Dave Jones |
bf89f3a |
+idmap_alloc_hashtable(struct idmap_hashtable *h)
|
|
Dave Jones |
bf89f3a |
+{
|
|
Dave Jones |
bf89f3a |
+ if (h->h_entries != NULL)
|
|
Dave Jones |
bf89f3a |
+ return;
|
|
Dave Jones |
bf89f3a |
+ h->h_entries = kcalloc(IDMAP_HASH_SZ,
|
|
Dave Jones |
bf89f3a |
+ sizeof(*h->h_entries),
|
|
Dave Jones |
bf89f3a |
+ GFP_KERNEL);
|
|
Dave Jones |
bf89f3a |
+}
|
|
Dave Jones |
bf89f3a |
+
|
|
Dave Jones |
bf89f3a |
+static void
|
|
Dave Jones |
bf89f3a |
+idmap_free_hashtable(struct idmap_hashtable *h)
|
|
Dave Jones |
bf89f3a |
+{
|
|
Dave Jones |
bf89f3a |
+ int i;
|
|
Dave Jones |
bf89f3a |
+
|
|
Dave Jones |
bf89f3a |
+ if (h->h_entries == NULL)
|
|
Dave Jones |
bf89f3a |
+ return;
|
|
Dave Jones |
bf89f3a |
+ for (i = 0; i < IDMAP_HASH_SZ; i++)
|
|
Dave Jones |
bf89f3a |
+ kfree(h->h_entries[i].ih_name);
|
|
Dave Jones |
bf89f3a |
+ kfree(h->h_entries);
|
|
Dave Jones |
bf89f3a |
+}
|
|
Dave Jones |
bf89f3a |
+
|
|
Dave Jones |
bf89f3a |
void
|
|
Dave Jones |
bf89f3a |
nfs_idmap_delete(struct nfs_client *clp)
|
|
Dave Jones |
bf89f3a |
{
|
|
Dave Jones |
bf89f3a |
struct idmap *idmap = clp->cl_idmap;
|
|
Dave Jones |
bf89f3a |
- int i;
|
|
Dave Jones |
bf89f3a |
|
|
Dave Jones |
bf89f3a |
if (!idmap)
|
|
Dave Jones |
bf89f3a |
return;
|
|
Dave Jones |
bf89f3a |
rpc_unlink(idmap->idmap_dentry);
|
|
Dave Jones |
bf89f3a |
clp->cl_idmap = NULL;
|
|
Dave Jones |
bf89f3a |
- for (i = 0; i < ARRAY_SIZE(idmap->idmap_user_hash.h_entries); i++)
|
|
Dave Jones |
bf89f3a |
- kfree(idmap->idmap_user_hash.h_entries[i].ih_name);
|
|
Dave Jones |
bf89f3a |
- for (i = 0; i < ARRAY_SIZE(idmap->idmap_group_hash.h_entries); i++)
|
|
Dave Jones |
bf89f3a |
- kfree(idmap->idmap_group_hash.h_entries[i].ih_name);
|
|
Dave Jones |
bf89f3a |
+ idmap_free_hashtable(&idmap->idmap_user_hash);
|
|
Dave Jones |
bf89f3a |
+ idmap_free_hashtable(&idmap->idmap_group_hash);
|
|
Dave Jones |
bf89f3a |
kfree(idmap);
|
|
Dave Jones |
bf89f3a |
}
|
|
Dave Jones |
bf89f3a |
|
|
Dave Jones |
bf89f3a |
@@ -443,6 +462,8 @@ nfs_idmap_delete(struct nfs_client *clp)
|
|
Dave Jones |
bf89f3a |
static inline struct idmap_hashent *
|
|
Dave Jones |
bf89f3a |
idmap_name_hash(struct idmap_hashtable* h, const char *name, size_t len)
|
|
Dave Jones |
bf89f3a |
{
|
|
Dave Jones |
bf89f3a |
+ if (h->h_entries == NULL)
|
|
Dave Jones |
bf89f3a |
+ return NULL;
|
|
Dave Jones |
bf89f3a |
return &h->h_entries[fnvhash32(name, len) % IDMAP_HASH_SZ];
|
|
Dave Jones |
bf89f3a |
}
|
|
Dave Jones |
bf89f3a |
|
|
Dave Jones |
bf89f3a |
@@ -451,6 +472,8 @@ idmap_lookup_name(struct idmap_hashtable
|
|
Dave Jones |
bf89f3a |
{
|
|
Dave Jones |
bf89f3a |
struct idmap_hashent *he = idmap_name_hash(h, name, len);
|
|
Dave Jones |
bf89f3a |
|
|
Dave Jones |
bf89f3a |
+ if (he == NULL)
|
|
Dave Jones |
bf89f3a |
+ return NULL;
|
|
Dave Jones |
bf89f3a |
if (he->ih_namelen != len || memcmp(he->ih_name, name, len) != 0)
|
|
Dave Jones |
bf89f3a |
return NULL;
|
|
Dave Jones |
bf89f3a |
if (time_after(jiffies, he->ih_expires))
|
|
Dave Jones |
bf89f3a |
@@ -461,6 +484,8 @@ idmap_lookup_name(struct idmap_hashtable
|
|
Dave Jones |
bf89f3a |
static inline struct idmap_hashent *
|
|
Dave Jones |
bf89f3a |
idmap_id_hash(struct idmap_hashtable* h, __u32 id)
|
|
Dave Jones |
bf89f3a |
{
|
|
Dave Jones |
bf89f3a |
+ if (h->h_entries == NULL)
|
|
Dave Jones |
bf89f3a |
+ return NULL;
|
|
Dave Jones |
bf89f3a |
return &h->h_entries[fnvhash32(&id, sizeof(id)) % IDMAP_HASH_SZ];
|
|
Dave Jones |
bf89f3a |
}
|
|
Dave Jones |
bf89f3a |
|
|
Dave Jones |
bf89f3a |
@@ -468,6 +493,9 @@ static struct idmap_hashent *
|
|
Dave Jones |
bf89f3a |
idmap_lookup_id(struct idmap_hashtable *h, __u32 id)
|
|
Dave Jones |
bf89f3a |
{
|
|
Dave Jones |
bf89f3a |
struct idmap_hashent *he = idmap_id_hash(h, id);
|
|
Dave Jones |
bf89f3a |
+
|
|
Dave Jones |
bf89f3a |
+ if (he == NULL)
|
|
Dave Jones |
bf89f3a |
+ return NULL;
|
|
Dave Jones |
bf89f3a |
if (he->ih_id != id || he->ih_namelen == 0)
|
|
Dave Jones |
bf89f3a |
return NULL;
|
|
Dave Jones |
bf89f3a |
if (time_after(jiffies, he->ih_expires))
|
|
Dave Jones |
bf89f3a |
@@ -483,12 +511,14 @@ idmap_lookup_id(struct idmap_hashtable *
|
|
Dave Jones |
bf89f3a |
static inline struct idmap_hashent *
|
|
Dave Jones |
bf89f3a |
idmap_alloc_name(struct idmap_hashtable *h, char *name, size_t len)
|
|
Dave Jones |
bf89f3a |
{
|
|
Dave Jones |
bf89f3a |
+ idmap_alloc_hashtable(h);
|
|
Dave Jones |
bf89f3a |
return idmap_name_hash(h, name, len);
|
|
Dave Jones |
bf89f3a |
}
|
|
Dave Jones |
bf89f3a |
|
|
Dave Jones |
bf89f3a |
static inline struct idmap_hashent *
|
|
Dave Jones |
bf89f3a |
idmap_alloc_id(struct idmap_hashtable *h, __u32 id)
|
|
Dave Jones |
bf89f3a |
{
|
|
Dave Jones |
bf89f3a |
+ idmap_alloc_hashtable(h);
|
|
Dave Jones |
bf89f3a |
return idmap_id_hash(h, id);
|
|
Dave Jones |
bf89f3a |
}
|
|
Dave Jones |
bf89f3a |
|