|  | #ifndef _LINUX_UTSNAME_H | 
|  | #define _LINUX_UTSNAME_H | 
|  |  | 
|  | #define __OLD_UTS_LEN 8 | 
|  |  | 
|  | struct oldold_utsname { | 
|  | char sysname[9]; | 
|  | char nodename[9]; | 
|  | char release[9]; | 
|  | char version[9]; | 
|  | char machine[9]; | 
|  | }; | 
|  |  | 
|  | #define __NEW_UTS_LEN 64 | 
|  |  | 
|  | struct old_utsname { | 
|  | char sysname[65]; | 
|  | char nodename[65]; | 
|  | char release[65]; | 
|  | char version[65]; | 
|  | char machine[65]; | 
|  | }; | 
|  |  | 
|  | struct new_utsname { | 
|  | char sysname[__NEW_UTS_LEN + 1]; | 
|  | char nodename[__NEW_UTS_LEN + 1]; | 
|  | char release[__NEW_UTS_LEN + 1]; | 
|  | char version[__NEW_UTS_LEN + 1]; | 
|  | char machine[__NEW_UTS_LEN + 1]; | 
|  | char domainname[__NEW_UTS_LEN + 1]; | 
|  | }; | 
|  |  | 
|  | #ifdef __KERNEL__ | 
|  |  | 
|  | #include <linux/sched.h> | 
|  | #include <linux/kref.h> | 
|  | #include <linux/nsproxy.h> | 
|  | #include <linux/err.h> | 
|  |  | 
|  | enum uts_proc { | 
|  | UTS_PROC_OSTYPE, | 
|  | UTS_PROC_OSRELEASE, | 
|  | UTS_PROC_VERSION, | 
|  | UTS_PROC_HOSTNAME, | 
|  | UTS_PROC_DOMAINNAME, | 
|  | }; | 
|  |  | 
|  | struct user_namespace; | 
|  | extern struct user_namespace init_user_ns; | 
|  |  | 
|  | struct uts_namespace { | 
|  | struct kref kref; | 
|  | struct new_utsname name; | 
|  | struct user_namespace *user_ns; | 
|  | }; | 
|  | extern struct uts_namespace init_uts_ns; | 
|  |  | 
|  | #ifdef CONFIG_UTS_NS | 
|  | static inline void get_uts_ns(struct uts_namespace *ns) | 
|  | { | 
|  | kref_get(&ns->kref); | 
|  | } | 
|  |  | 
|  | extern struct uts_namespace *copy_utsname(unsigned long flags, | 
|  | struct task_struct *tsk); | 
|  | extern void free_uts_ns(struct kref *kref); | 
|  |  | 
|  | static inline void put_uts_ns(struct uts_namespace *ns) | 
|  | { | 
|  | kref_put(&ns->kref, free_uts_ns); | 
|  | } | 
|  | #else | 
|  | static inline void get_uts_ns(struct uts_namespace *ns) | 
|  | { | 
|  | } | 
|  |  | 
|  | static inline void put_uts_ns(struct uts_namespace *ns) | 
|  | { | 
|  | } | 
|  |  | 
|  | static inline struct uts_namespace *copy_utsname(unsigned long flags, | 
|  | struct task_struct *tsk) | 
|  | { | 
|  | if (flags & CLONE_NEWUTS) | 
|  | return ERR_PTR(-EINVAL); | 
|  |  | 
|  | return tsk->nsproxy->uts_ns; | 
|  | } | 
|  | #endif | 
|  |  | 
|  | #ifdef CONFIG_PROC_SYSCTL | 
|  | extern void uts_proc_notify(enum uts_proc proc); | 
|  | #else | 
|  | static inline void uts_proc_notify(enum uts_proc proc) | 
|  | { | 
|  | } | 
|  | #endif | 
|  |  | 
|  | static inline struct new_utsname *utsname(void) | 
|  | { | 
|  | return ¤t->nsproxy->uts_ns->name; | 
|  | } | 
|  |  | 
|  | static inline struct new_utsname *init_utsname(void) | 
|  | { | 
|  | return &init_uts_ns.name; | 
|  | } | 
|  |  | 
|  | extern struct rw_semaphore uts_sem; | 
|  |  | 
|  | #endif /* __KERNEL__ */ | 
|  |  | 
|  | #endif /* _LINUX_UTSNAME_H */ |