netfilter: nf_nat: fix inverted logic for persistent NAT mappings
[linux-2.6/mini2440.git] / include / linux / user_namespace.h
blobcc4f45361dbbc8a956f9a9fad2a865dc7f4add33
1 #ifndef _LINUX_USER_NAMESPACE_H
2 #define _LINUX_USER_NAMESPACE_H
4 #include <linux/kref.h>
5 #include <linux/nsproxy.h>
6 #include <linux/sched.h>
7 #include <linux/err.h>
9 #define UIDHASH_BITS (CONFIG_BASE_SMALL ? 3 : 8)
10 #define UIDHASH_SZ (1 << UIDHASH_BITS)
12 struct user_namespace {
13 struct kref kref;
14 struct hlist_head uidhash_table[UIDHASH_SZ];
15 struct user_struct *creator;
16 struct work_struct destroyer;
19 extern struct user_namespace init_user_ns;
21 #ifdef CONFIG_USER_NS
23 static inline struct user_namespace *get_user_ns(struct user_namespace *ns)
25 if (ns)
26 kref_get(&ns->kref);
27 return ns;
30 extern int create_user_ns(struct cred *new);
31 extern void free_user_ns(struct kref *kref);
33 static inline void put_user_ns(struct user_namespace *ns)
35 if (ns)
36 kref_put(&ns->kref, free_user_ns);
39 #else
41 static inline struct user_namespace *get_user_ns(struct user_namespace *ns)
43 return &init_user_ns;
46 static inline int create_user_ns(struct cred *new)
48 return -EINVAL;
51 static inline void put_user_ns(struct user_namespace *ns)
55 #endif
57 #endif /* _LINUX_USER_H */