Add new kernel compatibilty module code
[~emulex/for-vlad/old/compat.git] / compat-2.6.25.h
1 #ifndef LINUX_26_25_COMPAT_H
2 #define LINUX_26_25_COMPAT_H
3
4 #include <linux/autoconf.h>
5 #include <linux/version.h>
6
7 /* Compat work for 2.6.24 */
8 #if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,25))
9
10 #include <linux/types.h>
11 #include <linux/io.h>
12 #include <linux/hw_random.h>
13 #include <linux/leds.h>
14 #include <linux/kernel.h>
15 #include <linux/netdevice.h>
16 #include <asm-generic/bug.h>
17
18 #define __WARN(foo) dump_stack()
19
20 #define dev_emerg(dev, format, arg...)          \
21         dev_printk(KERN_EMERG , dev , format , ## arg)
22 #define dev_alert(dev, format, arg...)          \
23         dev_printk(KERN_ALERT , dev , format , ## arg)
24 #define dev_crit(dev, format, arg...)           \
25         dev_printk(KERN_CRIT , dev , format , ## arg)
26
27 extern int              __dev_addr_sync(struct dev_addr_list **to, int *to_count, struct dev_addr_list **from, int *from_count);
28 extern void             __dev_addr_unsync(struct dev_addr_list **to, int *to_count, struct dev_addr_list **from, int *from_count);
29
30 #define seq_file_net &init_net;
31
32 /* The patch:
33  * commit 8b5f6883683c91ad7e1af32b7ceeb604d68e2865
34  * Author: Marcin Slusarz <marcin.slusarz@gmail.com>
35  * Date:   Fri Feb 8 04:20:12 2008 -0800
36  *
37  *     byteorder: move le32_add_cpu & friends from OCFS2 to core
38  *
39  * moves le*_add_cpu and be*_add_cpu functions from OCFS2 to core
40  * header (1st) and converted some existing code to it. We port
41  * it here as later kernels will most likely use it.
42  */
43 static inline void le16_add_cpu(__le16 *var, u16 val)
44 {
45         *var = cpu_to_le16(le16_to_cpu(*var) + val);
46 }
47
48 static inline void le32_add_cpu(__le32 *var, u32 val)
49 {
50         *var = cpu_to_le32(le32_to_cpu(*var) + val);
51 }
52
53 static inline void le64_add_cpu(__le64 *var, u64 val)
54 {
55         *var = cpu_to_le64(le64_to_cpu(*var) + val);
56 }
57
58 static inline void be16_add_cpu(__be16 *var, u16 val)
59 {
60         u16 v = be16_to_cpu(*var);
61         *var = cpu_to_be16(v + val);
62 }
63
64 static inline void be32_add_cpu(__be32 *var, u32 val)
65 {
66         u32 v = be32_to_cpu(*var);
67         *var = cpu_to_be32(v + val);
68 }
69
70 static inline void be64_add_cpu(__be64 *var, u64 val)
71 {
72         u64 v = be64_to_cpu(*var);
73         *var = cpu_to_be64(v + val);
74 }
75
76 /* 2.6.25 changes hwrng_unregister()'s behaviour by supporting 
77  * suspend of its parent device (the misc device, which is itself the
78  * hardware random number generator). It does this by passing a parameter to
79  * unregister_miscdev() which is not supported in older kernels. The suspend
80  * parameter allows us to enable access to the device's hardware
81  * number generator during suspend. As far as wireless is concerned this means
82  * if a driver goes to suspend it you won't have the HNR available in
83  * older kernels. */
84 static inline void __hwrng_unregister(struct hwrng *rng, bool suspended)
85 {
86         hwrng_unregister(rng);
87 }
88
89 static inline void led_classdev_unregister_suspended(struct led_classdev *lcd)
90 {
91         led_classdev_unregister(lcd);
92 }
93
94 /**
95  * The following things are out of ./include/linux/kernel.h
96  * The new iwlwifi driver is using them.
97  */
98 extern int strict_strtoul(const char *, unsigned int, unsigned long *);
99 extern int strict_strtol(const char *, unsigned int, long *);
100
101 #endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,25)) */
102
103 #endif /* LINUX_26_25_COMPAT_H */