compat: Mask seq_user_ns as RHEL6.7 backports it
[~tnikolova/compat/.git] / include / linux / compat-3.7.h
1 #ifndef LINUX_3_7_COMPAT_H
2 #define LINUX_3_7_COMPAT_H
3
4 #include <linux/version.h>
5
6 #if (LINUX_VERSION_CODE < KERNEL_VERSION(3,7,0))
7
8 #include <linux/workqueue.h>
9 #include <linux/timer.h>
10 #include <linux/pci.h>
11 #include <linux/pci_regs.h>
12 #include <linux/mm.h>
13 #include <linux/user_namespace.h>
14 #include <linux/file.h>
15 #include <linux/fdtable.h>
16 #include <linux/seq_file.h>
17
18 #ifndef VM_DONTDUMP
19 #define VM_DONTDUMP    VM_NODUMP
20 #endif
21
22 #ifndef INIT_DEFERRABLE_WORK
23 #define INIT_DEFERRABLE_WORK(_work, _func) INIT_DELAYED_WORK_DEFERRABLE(_work, _func)
24 #endif
25
26 #ifndef DECLARE_DEFERRABLE_WORK
27 #define DECLARE_DEFERRABLE_WORK(n, f) DECLARE_DEFERRED_WORK(n, f)
28 #endif
29
30 #ifdef CONFIG_USER_NS
31
32 #define seq_user_ns LINUX_BACKPORT(seq_user_ns)
33 #if (LINUX_VERSION_CODE > KERNEL_VERSION(2,6,38))
34 static inline struct user_namespace *seq_user_ns(struct seq_file *seq)
35 {
36         struct file *f = container_of((void *) seq, struct file, private_data);
37
38         return f->f_cred->user_ns;
39 }
40 #else
41 static inline struct user_namespace *seq_user_ns(struct seq_file *seq)
42 {
43         return current_user_ns();
44 }
45 #endif /* (LINUX_VERSION_CODE > KERNEL_VERSION(2,6,38)) */
46
47 #else
48 static inline struct user_namespace *seq_user_ns(struct seq_file *seq)
49 {
50         extern struct user_namespace init_user_ns;
51         return &init_user_ns;
52 }
53 #endif /* CONFIG_USER_NS */
54
55 #define mod_delayed_work LINUX_BACKPORT(mod_delayed_work)
56 bool mod_delayed_work(struct workqueue_struct *wq, struct delayed_work *dwork,
57                       unsigned long delay);
58
59 /* Backports tty_lock: Localise the lock */
60 #define tty_lock(__tty) tty_lock()
61 #define tty_unlock(__tty) tty_unlock()
62
63 #define tty_port_register_device(port, driver, index, device) \
64         tty_register_device(driver, index, device)
65
66 #define pcie_capability_read_word LINUX_BACKPORT(pcie_capability_read_word)
67 int pcie_capability_read_word(struct pci_dev *dev, int pos, u16 *val);
68 #define pcie_capability_read_dword LINUX_BACKPORT(pcie_capability_read_dword)
69 int pcie_capability_read_dword(struct pci_dev *dev, int pos, u32 *val);
70 #define pcie_capability_write_word LINUX_BACKPORT(pcie_capability_write_word)
71 int pcie_capability_write_word(struct pci_dev *dev, int pos, u16 val);
72 #define pcie_capability_write_dword LINUX_BACKPORT(pcie_capability_write_dword)
73 int pcie_capability_write_dword(struct pci_dev *dev, int pos, u32 val);
74 #define pcie_capability_clear_and_set_word LINUX_BACKPORT(pcie_capability_clear_and_set_word)
75 int pcie_capability_clear_and_set_word(struct pci_dev *dev, int pos,
76                                        u16 clear, u16 set);
77 #define pcie_capability_clear_and_set_dword LINUX_BACKPORT(pcie_capability_clear_and_set_dword)
78 int pcie_capability_clear_and_set_dword(struct pci_dev *dev, int pos,
79                                         u32 clear, u32 set);
80 #define pcie_capability_set_word LINUX_BACKPORT(pcie_capability_set_word)
81 static inline int pcie_capability_set_word(struct pci_dev *dev, int pos,
82                                            u16 set)
83 {
84         return pcie_capability_clear_and_set_word(dev, pos, 0, set);
85 }
86
87 #define pcie_capability_set_dword LINUX_BACKPORT(pcie_capability_set_dword)
88 static inline int pcie_capability_set_dword(struct pci_dev *dev, int pos,
89                                             u32 set)
90 {
91         return pcie_capability_clear_and_set_dword(dev, pos, 0, set);
92 }
93
94 #define pcie_capability_clear_word LINUX_BACKPORT(pcie_capability_clear_word)
95 static inline int pcie_capability_clear_word(struct pci_dev *dev, int pos,
96                                              u16 clear)
97 {
98         return pcie_capability_clear_and_set_word(dev, pos, clear, 0);
99 }
100
101 #define pcie_capability_clear_dword LINUX_BACKPORT(pcie_capability_clear_dword)
102 static inline int pcie_capability_clear_dword(struct pci_dev *dev, int pos,
103                                               u32 clear)
104 {
105         return pcie_capability_clear_and_set_dword(dev, pos, clear, 0);
106 }
107
108 #define PCI_EXP_LNKSTA2                 50      /* Link Status 2 */
109
110 #define MAX_IDR_SHIFT (sizeof(int)*8 - 1)
111 #define MAX_IDR_BIT (1U << MAX_IDR_SHIFT)
112 #define MAX_IDR_MASK (MAX_IDR_BIT - 1)
113
114 /* IPoIB section */
115 #ifndef IFLA_IPOIB_MAX
116 enum {
117         IFLA_IPOIB_UNSPEC,
118         IFLA_IPOIB_PKEY,
119         IFLA_IPOIB_MODE,
120         IFLA_IPOIB_UMCAST,
121         __IFLA_IPOIB_MAX
122 };
123
124 enum {
125         IPOIB_MODE_DATAGRAM  = 0, /* using unreliable datagram QPs */
126         IPOIB_MODE_CONNECTED = 1, /* using connected QPs */
127 };
128
129 #define IFLA_IPOIB_MAX (__IFLA_IPOIB_MAX - 1)
130 #endif
131
132 #define FMODE_PATH              ((__force fmode_t)0x4000)
133
134 #define fget_light LINUX_BACKPORT(fget_light)
135 extern struct file *fget_light(unsigned int fd, int *fput_needed);
136
137 #endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(3,7,0)) */
138
139 #endif /* LINUX_3_7_COMPAT_H */