Merge branch 'x86-cleanups-for-linus' of git://git.kernel.org/pub/scm/linux/kernel...
[firefly-linux-kernel-4.4.55.git] / include / linux / personality.h
1 #ifndef _LINUX_PERSONALITY_H
2 #define _LINUX_PERSONALITY_H
3
4 #ifdef __KERNEL__
5
6 /*
7  * Handling of different ABIs (personalities).
8  */
9
10 struct exec_domain;
11 struct pt_regs;
12
13 extern int              register_exec_domain(struct exec_domain *);
14 extern int              unregister_exec_domain(struct exec_domain *);
15 extern int              __set_personality(unsigned int);
16
17 #endif /* __KERNEL__ */
18
19 /*
20  * Flags for bug emulation.
21  *
22  * These occupy the top three bytes.
23  */
24 enum {
25         UNAME26 =               0x0020000,
26         ADDR_NO_RANDOMIZE =     0x0040000,      /* disable randomization of VA space */
27         FDPIC_FUNCPTRS =        0x0080000,      /* userspace function ptrs point to descriptors
28                                                  * (signal handling)
29                                                  */
30         MMAP_PAGE_ZERO =        0x0100000,
31         ADDR_COMPAT_LAYOUT =    0x0200000,
32         READ_IMPLIES_EXEC =     0x0400000,
33         ADDR_LIMIT_32BIT =      0x0800000,
34         SHORT_INODE =           0x1000000,
35         WHOLE_SECONDS =         0x2000000,
36         STICKY_TIMEOUTS =       0x4000000,
37         ADDR_LIMIT_3GB =        0x8000000,
38 };
39
40 /*
41  * Security-relevant compatibility flags that must be
42  * cleared upon setuid or setgid exec:
43  */
44 #define PER_CLEAR_ON_SETID (READ_IMPLIES_EXEC  | \
45                             ADDR_NO_RANDOMIZE  | \
46                             ADDR_COMPAT_LAYOUT | \
47                             MMAP_PAGE_ZERO)
48
49 /*
50  * Personality types.
51  *
52  * These go in the low byte.  Avoid using the top bit, it will
53  * conflict with error returns.
54  */
55 enum {
56         PER_LINUX =             0x0000,
57         PER_LINUX_32BIT =       0x0000 | ADDR_LIMIT_32BIT,
58         PER_LINUX_FDPIC =       0x0000 | FDPIC_FUNCPTRS,
59         PER_SVR4 =              0x0001 | STICKY_TIMEOUTS | MMAP_PAGE_ZERO,
60         PER_SVR3 =              0x0002 | STICKY_TIMEOUTS | SHORT_INODE,
61         PER_SCOSVR3 =           0x0003 | STICKY_TIMEOUTS |
62                                          WHOLE_SECONDS | SHORT_INODE,
63         PER_OSR5 =              0x0003 | STICKY_TIMEOUTS | WHOLE_SECONDS,
64         PER_WYSEV386 =          0x0004 | STICKY_TIMEOUTS | SHORT_INODE,
65         PER_ISCR4 =             0x0005 | STICKY_TIMEOUTS,
66         PER_BSD =               0x0006,
67         PER_SUNOS =             0x0006 | STICKY_TIMEOUTS,
68         PER_XENIX =             0x0007 | STICKY_TIMEOUTS | SHORT_INODE,
69         PER_LINUX32 =           0x0008,
70         PER_LINUX32_3GB =       0x0008 | ADDR_LIMIT_3GB,
71         PER_IRIX32 =            0x0009 | STICKY_TIMEOUTS,/* IRIX5 32-bit */
72         PER_IRIXN32 =           0x000a | STICKY_TIMEOUTS,/* IRIX6 new 32-bit */
73         PER_IRIX64 =            0x000b | STICKY_TIMEOUTS,/* IRIX6 64-bit */
74         PER_RISCOS =            0x000c,
75         PER_SOLARIS =           0x000d | STICKY_TIMEOUTS,
76         PER_UW7 =               0x000e | STICKY_TIMEOUTS | MMAP_PAGE_ZERO,
77         PER_OSF4 =              0x000f,                  /* OSF/1 v4 */
78         PER_HPUX =              0x0010,
79         PER_MASK =              0x00ff,
80 };
81
82 #ifdef __KERNEL__
83
84 /*
85  * Description of an execution domain.
86  * 
87  * The first two members are refernced from assembly source
88  * and should stay where they are unless explicitly needed.
89  */
90 typedef void (*handler_t)(int, struct pt_regs *);
91
92 struct exec_domain {
93         const char              *name;          /* name of the execdomain */
94         handler_t               handler;        /* handler for syscalls */
95         unsigned char           pers_low;       /* lowest personality */
96         unsigned char           pers_high;      /* highest personality */
97         unsigned long           *signal_map;    /* signal mapping */
98         unsigned long           *signal_invmap; /* reverse signal mapping */
99         struct map_segment      *err_map;       /* error mapping */
100         struct map_segment      *socktype_map;  /* socket type mapping */
101         struct map_segment      *sockopt_map;   /* socket option mapping */
102         struct map_segment      *af_map;        /* address family mapping */
103         struct module           *module;        /* module context of the ed. */
104         struct exec_domain      *next;          /* linked list (internal) */
105 };
106
107 /*
108  * Return the base personality without flags.
109  */
110 #define personality(pers)       (pers & PER_MASK)
111
112
113 /*
114  * Change personality of the currently running process.
115  */
116 #define set_personality(pers) \
117         ((current->personality == (pers)) ? 0 : __set_personality(pers))
118
119 #endif /* __KERNEL__ */
120
121 #endif /* _LINUX_PERSONALITY_H */