5e9d4626453b61b7328a0dc3e094a7bcae2ff2e9
[linux-2.6.git] / include / linux / vs_base.h
1 #ifndef _VX_VS_BASE_H
2 #define _VX_VS_BASE_H
3
4 #include "vserver/context.h"
5
6 #define VX_IRQ        0x4000
7 #define VX_IRQ_MASK   0xF000
8 #include <linux/hardirq.h>
9
10 #define vx_task_xid(t)  ((t)->xid)
11
12 #define vx_current_xid() vx_task_xid(current)
13
14 #define current_vx_info() (current->vx_info)
15
16 #define vx_check(c,m)   __vx_check(vx_current_xid(),c,m|VX_IRQ)
17
18 #define vx_weak_check(c,m)      ((m) ? vx_check(c,m) : 1)
19
20
21 /*
22  * check current context for ADMIN/WATCH and
23  * optionally against supplied argument
24  */
25 static inline int __vx_check(xid_t cid, xid_t id, unsigned int mode)
26 {
27         if (mode & VX_ARG_MASK) {
28                 if ((mode & VX_IDENT) &&
29                         (id == cid))
30                         return 1;
31         }
32         if (mode & VX_ATR_MASK) {
33                 if ((mode & VX_DYNAMIC) &&
34                         (id >= MIN_D_CONTEXT) &&
35                         (id <= MAX_S_CONTEXT))
36                         return 1;
37                 if ((mode & VX_STATIC) &&
38                         (id > 1) && (id < MIN_D_CONTEXT))
39                         return 1;
40         }
41         if ((mode & VX_IRQ) && (unlikely(in_interrupt())))
42                 return 1;
43
44         return (((mode & VX_ADMIN) && (cid == 0)) ||
45                 ((mode & VX_WATCH) && (cid == 1)) ||
46                 ((mode & VX_HOSTID) && (id == 0)));
47 }
48
49
50 #define __vx_state(v)   ((v) ? ((v)->vx_state) : 0)
51
52 #define vx_info_state(v,m)      (__vx_state(v) & (m))
53
54
55 /* generic flag merging */
56
57 #define vx_check_flags(v,m,f)   (((v) & (m)) ^ (f))
58
59 #define vx_mask_flags(v,f,m)    (((v) & ~(m)) | ((f) & (m)))
60
61 #define vx_mask_mask(v,f,m)     (((v) & ~(m)) | ((v) & (f) & (m)))
62
63 #define vx_check_bit(v,n)       ((v) & (1LL << (n)))
64
65
66 /* context flags */
67
68 #define __vx_flags(v)   ((v) ? (v)->vx_flags : 0)
69
70 #define vx_current_flags()      __vx_flags(current->vx_info)
71
72 #define vx_info_flags(v,m,f) \
73         vx_check_flags(__vx_flags(v),(m),(f))
74
75 #define task_vx_flags(t,m,f) \
76         ((t) && vx_info_flags((t)->vx_info, (m), (f)))
77
78 #define vx_flags(m,f)   vx_info_flags(current->vx_info,(m),(f))
79
80
81 /* context caps */
82
83 #define __vx_ccaps(v)   ((v) ? (v)->vx_ccaps : 0)
84
85 #define vx_current_ccaps()      __vx_ccaps(current->vx_info)
86
87 #define vx_info_ccaps(v,c)      (__vx_ccaps(v) & (c))
88
89 #define vx_ccaps(c)     vx_info_ccaps(current->vx_info,(c))
90
91
92 #define __vx_mcaps(v)   ((v) ? (v)->vx_ccaps >> 32UL : ~0 )
93
94 #define vx_info_mcaps(v,c)      (__vx_mcaps(v) & (c))
95
96 #define vx_mcaps(c)     vx_info_mcaps(current->vx_info,(c))
97
98
99 #define vx_current_bcaps() \
100         (((current->vx_info) && !vx_flags(VXF_STATE_SETUP, 0)) ? \
101         current->vx_info->vx_bcaps : cap_bset)
102
103
104 #define vx_current_initpid(n) \
105         (current->vx_info && \
106         (current->vx_info->vx_initpid == (n)))
107
108 #define vx_capable(b,c) (capable(b) || \
109         ((current->euid == 0) && vx_ccaps(c)))
110
111 #else
112 #warning duplicate inclusion
113 #endif