diff options
Diffstat (limited to 'fs/nfs/idmap.c')
-rw-r--r-- | fs/nfs/idmap.c | 91 |
1 files changed, 37 insertions, 54 deletions
diff --git a/fs/nfs/idmap.c b/fs/nfs/idmap.c index 62264e0b1ddb..e0ecd5a7e19a 100644 --- a/fs/nfs/idmap.c +++ b/fs/nfs/idmap.c | |||
@@ -142,8 +142,6 @@ static int nfs_map_numeric_to_string(__u32 id, char *buf, size_t buflen) | |||
142 | return snprintf(buf, buflen, "%u", id); | 142 | return snprintf(buf, buflen, "%u", id); |
143 | } | 143 | } |
144 | 144 | ||
145 | #ifdef CONFIG_NFS_USE_NEW_IDMAPPER | ||
146 | |||
147 | #include <linux/cred.h> | 145 | #include <linux/cred.h> |
148 | #include <linux/sunrpc/sched.h> | 146 | #include <linux/sunrpc/sched.h> |
149 | #include <linux/nfs4.h> | 147 | #include <linux/nfs4.h> |
@@ -169,7 +167,7 @@ struct key_type key_type_id_resolver = { | |||
169 | .read = user_read, | 167 | .read = user_read, |
170 | }; | 168 | }; |
171 | 169 | ||
172 | int nfs_idmap_init(void) | 170 | static int nfs_idmap_init_keyring(void) |
173 | { | 171 | { |
174 | struct cred *cred; | 172 | struct cred *cred; |
175 | struct key *keyring; | 173 | struct key *keyring; |
@@ -211,7 +209,7 @@ failed_put_cred: | |||
211 | return ret; | 209 | return ret; |
212 | } | 210 | } |
213 | 211 | ||
214 | void nfs_idmap_quit(void) | 212 | static void nfs_idmap_quit_keyring(void) |
215 | { | 213 | { |
216 | key_revoke(id_resolver_cache->thread_keyring); | 214 | key_revoke(id_resolver_cache->thread_keyring); |
217 | unregister_key_type(&key_type_id_resolver); | 215 | unregister_key_type(&key_type_id_resolver); |
@@ -328,43 +326,7 @@ static int nfs_idmap_lookup_id(const char *name, size_t namelen, | |||
328 | return ret; | 326 | return ret; |
329 | } | 327 | } |
330 | 328 | ||
331 | int nfs_map_name_to_uid(const struct nfs_server *server, const char *name, size_t namelen, __u32 *uid) | 329 | /* idmap classic begins here */ |
332 | { | ||
333 | if (nfs_map_string_to_numeric(name, namelen, uid)) | ||
334 | return 0; | ||
335 | return nfs_idmap_lookup_id(name, namelen, "uid", uid); | ||
336 | } | ||
337 | |||
338 | int nfs_map_group_to_gid(const struct nfs_server *server, const char *name, size_t namelen, __u32 *gid) | ||
339 | { | ||
340 | if (nfs_map_string_to_numeric(name, namelen, gid)) | ||
341 | return 0; | ||
342 | return nfs_idmap_lookup_id(name, namelen, "gid", gid); | ||
343 | } | ||
344 | |||
345 | int nfs_map_uid_to_name(const struct nfs_server *server, __u32 uid, char *buf, size_t buflen) | ||
346 | { | ||
347 | int ret = -EINVAL; | ||
348 | |||
349 | if (!(server->caps & NFS_CAP_UIDGID_NOMAP)) | ||
350 | ret = nfs_idmap_lookup_name(uid, "user", buf, buflen); | ||
351 | if (ret < 0) | ||
352 | ret = nfs_map_numeric_to_string(uid, buf, buflen); | ||
353 | return ret; | ||
354 | } | ||
355 | int nfs_map_gid_to_group(const struct nfs_server *server, __u32 gid, char *buf, size_t buflen) | ||
356 | { | ||
357 | int ret = -EINVAL; | ||
358 | |||
359 | if (!(server->caps & NFS_CAP_UIDGID_NOMAP)) | ||
360 | ret = nfs_idmap_lookup_name(gid, "group", buf, buflen); | ||
361 | if (ret < 0) | ||
362 | ret = nfs_map_numeric_to_string(gid, buf, buflen); | ||
363 | return ret; | ||
364 | } | ||
365 | |||
366 | #else /* CONFIG_NFS_USE_NEW_IDMAPPER not defined */ | ||
367 | |||
368 | #include <linux/module.h> | 330 | #include <linux/module.h> |
369 | #include <linux/mutex.h> | 331 | #include <linux/mutex.h> |
370 | #include <linux/init.h> | 332 | #include <linux/init.h> |
@@ -600,12 +562,21 @@ static struct notifier_block nfs_idmap_block = { | |||
600 | 562 | ||
601 | int nfs_idmap_init(void) | 563 | int nfs_idmap_init(void) |
602 | { | 564 | { |
603 | return rpc_pipefs_notifier_register(&nfs_idmap_block); | 565 | int ret; |
566 | ret = nfs_idmap_init_keyring(); | ||
567 | if (ret != 0) | ||
568 | goto out; | ||
569 | ret = rpc_pipefs_notifier_register(&nfs_idmap_block); | ||
570 | if (ret != 0) | ||
571 | nfs_idmap_quit_keyring(); | ||
572 | out: | ||
573 | return ret; | ||
604 | } | 574 | } |
605 | 575 | ||
606 | void nfs_idmap_quit(void) | 576 | void nfs_idmap_quit(void) |
607 | { | 577 | { |
608 | rpc_pipefs_notifier_unregister(&nfs_idmap_block); | 578 | rpc_pipefs_notifier_unregister(&nfs_idmap_block); |
579 | nfs_idmap_quit_keyring(); | ||
609 | } | 580 | } |
610 | 581 | ||
611 | /* | 582 | /* |
@@ -930,19 +901,27 @@ static unsigned int fnvhash32(const void *buf, size_t buflen) | |||
930 | int nfs_map_name_to_uid(const struct nfs_server *server, const char *name, size_t namelen, __u32 *uid) | 901 | int nfs_map_name_to_uid(const struct nfs_server *server, const char *name, size_t namelen, __u32 *uid) |
931 | { | 902 | { |
932 | struct idmap *idmap = server->nfs_client->cl_idmap; | 903 | struct idmap *idmap = server->nfs_client->cl_idmap; |
904 | int ret = -EINVAL; | ||
933 | 905 | ||
934 | if (nfs_map_string_to_numeric(name, namelen, uid)) | 906 | if (nfs_map_string_to_numeric(name, namelen, uid)) |
935 | return 0; | 907 | return 0; |
936 | return nfs_idmap_id(idmap, &idmap->idmap_user_hash, name, namelen, uid); | 908 | ret = nfs_idmap_lookup_id(name, namelen, "uid", uid); |
909 | if (ret < 0) | ||
910 | ret = nfs_idmap_id(idmap, &idmap->idmap_user_hash, name, namelen, uid); | ||
911 | return ret; | ||
937 | } | 912 | } |
938 | 913 | ||
939 | int nfs_map_group_to_gid(const struct nfs_server *server, const char *name, size_t namelen, __u32 *uid) | 914 | int nfs_map_group_to_gid(const struct nfs_server *server, const char *name, size_t namelen, __u32 *gid) |
940 | { | 915 | { |
941 | struct idmap *idmap = server->nfs_client->cl_idmap; | 916 | struct idmap *idmap = server->nfs_client->cl_idmap; |
917 | int ret = -EINVAL; | ||
942 | 918 | ||
943 | if (nfs_map_string_to_numeric(name, namelen, uid)) | 919 | if (nfs_map_string_to_numeric(name, namelen, gid)) |
944 | return 0; | 920 | return 0; |
945 | return nfs_idmap_id(idmap, &idmap->idmap_group_hash, name, namelen, uid); | 921 | ret = nfs_idmap_lookup_id(name, namelen, "gid", gid); |
922 | if (ret < 0) | ||
923 | ret = nfs_idmap_id(idmap, &idmap->idmap_group_hash, name, namelen, gid); | ||
924 | return ret; | ||
946 | } | 925 | } |
947 | 926 | ||
948 | int nfs_map_uid_to_name(const struct nfs_server *server, __u32 uid, char *buf, size_t buflen) | 927 | int nfs_map_uid_to_name(const struct nfs_server *server, __u32 uid, char *buf, size_t buflen) |
@@ -950,22 +929,26 @@ int nfs_map_uid_to_name(const struct nfs_server *server, __u32 uid, char *buf, s | |||
950 | struct idmap *idmap = server->nfs_client->cl_idmap; | 929 | struct idmap *idmap = server->nfs_client->cl_idmap; |
951 | int ret = -EINVAL; | 930 | int ret = -EINVAL; |
952 | 931 | ||
953 | if (!(server->caps & NFS_CAP_UIDGID_NOMAP)) | 932 | if (!(server->caps & NFS_CAP_UIDGID_NOMAP)) { |
954 | ret = nfs_idmap_name(idmap, &idmap->idmap_user_hash, uid, buf); | 933 | ret = nfs_idmap_lookup_name(uid, "user", buf, buflen); |
934 | if (ret < 0) | ||
935 | ret = nfs_idmap_name(idmap, &idmap->idmap_user_hash, uid, buf); | ||
936 | } | ||
955 | if (ret < 0) | 937 | if (ret < 0) |
956 | ret = nfs_map_numeric_to_string(uid, buf, buflen); | 938 | ret = nfs_map_numeric_to_string(uid, buf, buflen); |
957 | return ret; | 939 | return ret; |
958 | } | 940 | } |
959 | int nfs_map_gid_to_group(const struct nfs_server *server, __u32 uid, char *buf, size_t buflen) | 941 | int nfs_map_gid_to_group(const struct nfs_server *server, __u32 gid, char *buf, size_t buflen) |
960 | { | 942 | { |
961 | struct idmap *idmap = server->nfs_client->cl_idmap; | 943 | struct idmap *idmap = server->nfs_client->cl_idmap; |
962 | int ret = -EINVAL; | 944 | int ret = -EINVAL; |
963 | 945 | ||
964 | if (!(server->caps & NFS_CAP_UIDGID_NOMAP)) | 946 | if (!(server->caps & NFS_CAP_UIDGID_NOMAP)) { |
965 | ret = nfs_idmap_name(idmap, &idmap->idmap_group_hash, uid, buf); | 947 | ret = nfs_idmap_lookup_name(gid, "group", buf, buflen); |
948 | if (ret < 0) | ||
949 | ret = nfs_idmap_name(idmap, &idmap->idmap_group_hash, gid, buf); | ||
950 | } | ||
966 | if (ret < 0) | 951 | if (ret < 0) |
967 | ret = nfs_map_numeric_to_string(uid, buf, buflen); | 952 | ret = nfs_map_numeric_to_string(gid, buf, buflen); |
968 | return ret; | 953 | return ret; |
969 | } | 954 | } |
970 | |||
971 | #endif /* CONFIG_NFS_USE_NEW_IDMAPPER */ | ||