compat: backport in.h shortcuts added by Joe (2658)
[~emulex/for-vlad/old/compat.git] / include / linux / compat-2.6.25.h
1 #ifndef LINUX_26_25_COMPAT_H
2 #define LINUX_26_25_COMPAT_H
3
4 #include <linux/version.h>
5
6 /* Compat work for 2.6.24 */
7 #if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,25))
8
9 #include <linux/types.h>
10 #include <linux/io.h>
11 #include <linux/hw_random.h>
12 #include <linux/leds.h>
13 #include <linux/kernel.h>
14 #include <linux/netdevice.h>
15 #include <linux/pm.h>
16 #include <asm-generic/bug.h>
17 #include <linux/pm_qos_params.h>
18 #include <linux/pci.h>
19 #include <linux/in.h>
20 #include <linux/errno.h>
21
22 /*
23  * backports 2658fa803111dae1353602e7f586de8e537803e2
24  * We skip proto_ports_offset() as I'm lazy.
25  */
26
27 static inline bool ipv4_is_loopback(__be32 addr)
28 {
29         return (addr & htonl(0xff000000)) == htonl(0x7f000000);
30 }
31
32 static inline bool ipv4_is_multicast(__be32 addr)
33 {
34         return (addr & htonl(0xf0000000)) == htonl(0xe0000000);
35 }
36
37 static inline bool ipv4_is_local_multicast(__be32 addr)
38 {
39         return (addr & htonl(0xffffff00)) == htonl(0xe0000000);
40 }
41
42 static inline bool ipv4_is_lbcast(__be32 addr)
43 {
44         /* limited broadcast */
45         return addr == htonl(INADDR_BROADCAST);
46 }
47
48 static inline bool ipv4_is_zeronet(__be32 addr)
49 {
50         return (addr & htonl(0xff000000)) == htonl(0x00000000);
51 }
52
53 /* Special-Use IPv4 Addresses (RFC3330) */
54
55 static inline bool ipv4_is_private_10(__be32 addr)
56 {
57         return (addr & htonl(0xff000000)) == htonl(0x0a000000);
58 }
59
60 static inline bool ipv4_is_private_172(__be32 addr)
61 {
62         return (addr & htonl(0xfff00000)) == htonl(0xac100000);
63 }
64
65 static inline bool ipv4_is_private_192(__be32 addr)
66 {
67         return (addr & htonl(0xffff0000)) == htonl(0xc0a80000);
68 }
69
70 static inline bool ipv4_is_linklocal_169(__be32 addr)
71 {
72         return (addr & htonl(0xffff0000)) == htonl(0xa9fe0000);
73 }
74
75 static inline bool ipv4_is_anycast_6to4(__be32 addr)
76 {
77         return (addr & htonl(0xffffff00)) == htonl(0xc0586300);
78 }
79
80 static inline bool ipv4_is_test_192(__be32 addr)
81 {
82         return (addr & htonl(0xffffff00)) == htonl(0xc0000200);
83 }
84
85 static inline bool ipv4_is_test_198(__be32 addr)
86 {
87         return (addr & htonl(0xfffe0000)) == htonl(0xc6120000);
88 }
89
90 /*
91  * phys_addr_t was added as a generic arch typedef on 2.6.28,
92  * that backport is dealt with in compat-2.6.28.h
93  */
94 #if defined(CONFIG_X86) || defined(CONFIG_X86_64)
95
96 #if defined(CONFIG_64BIT) || defined(CONFIG_X86_PAE) || defined(CONFIG_PHYS_64BIT)
97 typedef u64 phys_addr_t;
98 #else
99 typedef u32 phys_addr_t;
100 #endif
101
102 #endif /* x86 */
103
104 /* The macro below uses a const upstream, this differs */
105
106 /**
107  * DEFINE_PCI_DEVICE_TABLE - macro used to describe a pci device table
108  * @_table: device table name
109  *
110  * This macro is used to create a struct pci_device_id array (a device table)
111  * in a generic manner.
112  */
113 #define DEFINE_PCI_DEVICE_TABLE(_table) \
114         const struct pci_device_id _table[] __devinitdata
115
116 /*
117  * Backport work for QoS dependencies (kernel/pm_qos_params.c)
118  * pm-qos stuff written by mark gross mgross@linux.intel.com.
119  *
120  * ipw2100 now makes use of:
121  *
122  * pm_qos_add_requirement(),
123  * pm_qos_update_requirement() and
124  * pm_qos_remove_requirement() from it
125  *
126  * mac80211 uses the network latency to determine if to enable or not
127  * dynamic PS. mac80211 also and registers a notifier for when
128  * the latency changes. Since older kernels do no thave pm-qos stuff
129  * we just implement it completley here and register it upon cfg80211
130  * init. I haven't tested ipw2100 on 2.6.24 though.
131  *
132  * This pm-qos implementation is copied verbatim from the kernel
133  * written by mark gross mgross@linux.intel.com. You don't have
134  * to do anythinig to use pm-qos except use the same exported
135  * routines as used in newer kernels. The compat_pm_qos_power_init()
136  * defned below is used by the compat module to initialize pm-qos.
137  */
138 int compat_pm_qos_power_init(void);
139 int compat_pm_qos_power_deinit(void);
140
141 /*
142  * 2.6.25 adds PM_EVENT_HIBERNATE as well here but
143  * we don't have this on <= 2.6.23)
144  */
145 #ifndef PM_EVENT_SLEEP /* some distribution have mucked with their own headers to add this.. */
146 #define PM_EVENT_SLEEP  (PM_EVENT_SUSPEND)
147 #endif
148
149 /* Although we don't care about wimax this is needed for rfkill input stuff */
150 #define KEY_WIMAX               246
151
152 /* Although pm_qos stuff is not implemented on <= 2.6.24 lets keep the define */
153 #define PM_QOS_DEFAULT_VALUE -1
154
155 #define __WARN(foo) dump_stack()
156
157 #define dev_emerg(dev, format, arg...)          \
158         dev_printk(KERN_EMERG , dev , format , ## arg)
159 #define dev_alert(dev, format, arg...)          \
160         dev_printk(KERN_ALERT , dev , format , ## arg)
161 #define dev_crit(dev, format, arg...)           \
162         dev_printk(KERN_CRIT , dev , format , ## arg)
163
164 extern int              __dev_addr_sync(struct dev_addr_list **to, int *to_count, struct dev_addr_list **from, int *from_count);
165 extern void             __dev_addr_unsync(struct dev_addr_list **to, int *to_count, struct dev_addr_list **from, int *from_count);
166
167 #define seq_file_net &init_net;
168
169 enum nf_inet_hooks {
170         NF_INET_PRE_ROUTING = 0,
171         NF_INET_LOCAL_IN = 1,
172         NF_INET_FORWARD = 2,
173         NF_INET_LOCAL_OUT = 3,
174         NF_INET_POST_ROUTING = 4,
175         NF_INET_NUMHOOKS = 5
176 };
177
178 /* The patch:
179  * commit 8b5f6883683c91ad7e1af32b7ceeb604d68e2865
180  * Author: Marcin Slusarz <marcin.slusarz@gmail.com>
181  * Date:   Fri Feb 8 04:20:12 2008 -0800
182  *
183  *     byteorder: move le32_add_cpu & friends from OCFS2 to core
184  *
185  * moves le*_add_cpu and be*_add_cpu functions from OCFS2 to core
186  * header (1st) and converted some existing code to it. We port
187  * it here as later kernels will most likely use it.
188  */
189 static inline void le16_add_cpu(__le16 *var, u16 val)
190 {
191         *var = cpu_to_le16(le16_to_cpu(*var) + val);
192 }
193
194 static inline void le32_add_cpu(__le32 *var, u32 val)
195 {
196         *var = cpu_to_le32(le32_to_cpu(*var) + val);
197 }
198
199 static inline void le64_add_cpu(__le64 *var, u64 val)
200 {
201         *var = cpu_to_le64(le64_to_cpu(*var) + val);
202 }
203
204 static inline void be16_add_cpu(__be16 *var, u16 val)
205 {
206         u16 v = be16_to_cpu(*var);
207         *var = cpu_to_be16(v + val);
208 }
209
210 static inline void be32_add_cpu(__be32 *var, u32 val)
211 {
212         u32 v = be32_to_cpu(*var);
213         *var = cpu_to_be32(v + val);
214 }
215
216 static inline void be64_add_cpu(__be64 *var, u64 val)
217 {
218         u64 v = be64_to_cpu(*var);
219         *var = cpu_to_be64(v + val);
220 }
221
222 /* 2.6.25 changes hwrng_unregister()'s behaviour by supporting
223  * suspend of its parent device (the misc device, which is itself the
224  * hardware random number generator). It does this by passing a parameter to
225  * unregister_miscdev() which is not supported in older kernels. The suspend
226  * parameter allows us to enable access to the device's hardware
227  * number generator during suspend. As far as wireless is concerned this means
228  * if a driver goes to suspend it you won't have the HNR available in
229  * older kernels. */
230 static inline void __hwrng_unregister(struct hwrng *rng, bool suspended)
231 {
232         hwrng_unregister(rng);
233 }
234
235 static inline void led_classdev_unregister_suspended(struct led_classdev *lcd)
236 {
237         led_classdev_unregister(lcd);
238 }
239
240 /**
241  * The following things are out of ./include/linux/kernel.h
242  * The new iwlwifi driver is using them.
243  */
244 extern int strict_strtoul(const char *, unsigned int, unsigned long *);
245 extern int strict_strtol(const char *, unsigned int, long *);
246
247 #else
248 /*
249  * Kernels >= 2.6.25 have pm-qos and its initialized as part of
250  * the bootup process
251  */
252 static inline int compat_pm_qos_power_init(void)
253 {
254         return 0;
255 }
256
257 static inline int compat_pm_qos_power_deinit(void)
258 {
259         return 0;
260 }
261 #endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,25)) */
262
263 #endif /* LINUX_26_25_COMPAT_H */