compat: Add __skb_frag_unref
[~tnikolova/compat/.git] / include / linux / compat-3.2.h
1 #ifndef LINUX_3_2_COMPAT_H
2 #define LINUX_3_2_COMPAT_H
3
4 #include <linux/version.h>
5
6 #if (LINUX_VERSION_CODE < KERNEL_VERSION(3,2,0))
7
8 #include <linux/skbuff.h>
9 #include <linux/dma-mapping.h>
10 #include <linux/ethtool.h>
11
12 /* backports b4625dab */
13 #define  SDIO_CCCR_REV_3_00    3       /* CCCR/FBR Version 3.00 */
14 #define  SDIO_SDIO_REV_3_00    4       /* SDIO Spec Version 3.00 */
15
16 #define PMSG_IS_AUTO(msg)       (((msg).event & PM_EVENT_AUTO) != 0)
17
18 extern int __ethtool_get_settings(struct net_device *dev,
19                                   struct ethtool_cmd *cmd);
20
21 #ifdef CONFIG_COMPAT_SKB_FRAG_NEEDED
22
23 /**
24  * skb_frag_page - retrieve the page refered to by a paged fragment
25  * @frag: the paged fragment
26  *
27  * Returns the &struct page associated with @frag.
28  */
29 static inline struct page *skb_frag_page(const skb_frag_t *frag)
30 {
31         return frag->page;
32 }
33
34 /**
35  * __skb_frag_set_page - sets the page contained in a paged fragment
36  * @frag: the paged fragment
37  * @page: the page to set
38  *
39  * Sets the fragment @frag to contain @page.
40  */
41 static inline void __skb_frag_set_page(skb_frag_t *frag, struct page *page)
42 {
43         frag->page = page;
44 }
45
46 /**
47  * skb_frag_set_page - sets the page contained in a paged fragment of an skb
48  * @skb: the buffer
49  * @f: the fragment offset
50  * @page: the page to set
51  *
52  * Sets the @f'th fragment of @skb to contain @page.
53  */
54 static inline void skb_frag_set_page(struct sk_buff *skb, int f,
55                                      struct page *page)
56 {
57         __skb_frag_set_page(&skb_shinfo(skb)->frags[f], page);
58 }
59
60 /**
61  * skb_frag_address_safe - gets the address of the data contained in a paged fragment
62  * @frag: the paged fragment buffer
63  *
64  * Returns the address of the data within @frag. Checks that the page
65  * is mapped and returns %NULL otherwise.
66  */
67 static inline void *skb_frag_address_safe(const skb_frag_t *frag)
68 {
69         void *ptr = page_address(skb_frag_page(frag));
70         if (unlikely(!ptr))
71                 return NULL;
72
73         return ptr + frag->page_offset;
74 }
75
76 /**
77  * skb_frag_dma_map - maps a paged fragment via the DMA API
78  * @device: the device to map the fragment to
79  * @frag: the paged fragment to map
80  * @offset: the offset within the fragment (starting at the
81  *          fragment's own offset)
82  * @size: the number of bytes to map
83  * @direction: the direction of the mapping (%PCI_DMA_*)
84  *
85  * Maps the page associated with @frag to @device.
86  */
87 static inline dma_addr_t skb_frag_dma_map(struct device *dev,
88                                           const skb_frag_t *frag,
89                                           size_t offset, size_t size,
90                                           enum dma_data_direction dir)
91 {
92         return dma_map_page(dev, skb_frag_page(frag),
93                             frag->page_offset + offset, size, dir);
94 }
95
96 #define ETH_P_TDLS      0x890D          /* TDLS */
97
98 static inline unsigned int skb_frag_size(const skb_frag_t *frag)
99 {
100         return frag->size;
101 }
102
103 static inline void skb_frag_size_set(skb_frag_t *frag, unsigned int size)
104 {
105         frag->size = size;
106 }
107
108 static inline void skb_frag_size_add(skb_frag_t *frag, int delta)
109 {
110         frag->size += delta;
111 }
112
113 static inline void skb_frag_size_sub(skb_frag_t *frag, int delta)
114 {
115         frag->size -= delta;
116 }
117
118 /**
119  * __skb_frag_unref - release a reference on a paged fragment.
120  * @frag: the paged fragment
121  *
122  * Releases a reference on the paged fragment @frag.
123  */
124 static inline void __skb_frag_unref(skb_frag_t *frag)
125 {
126         put_page(skb_frag_page(frag));
127 }
128
129 #endif /* CONFIG_COMPAT_SKB_FRAG_NEEDED */
130
131 static inline char *hex_byte_pack(char *buf, u8 byte)
132 {
133         *buf++ = hex_asc_hi(byte);
134         *buf++ = hex_asc_lo(byte);
135         return buf;
136 }
137
138 /* module_platform_driver() - Helper macro for drivers that don't do
139  * anything special in module init/exit.  This eliminates a lot of
140  * boilerplate.  Each module may only use this macro once, and
141  * calling it replaces module_init() and module_exit()
142  */
143 #define module_platform_driver(__platform_driver) \
144         module_driver(__platform_driver, platform_driver_register, \
145                         platform_driver_unregister)
146
147 static inline void *dma_zalloc_coherent(struct device *dev, size_t size,
148                                         dma_addr_t *dma_handle, gfp_t flag)
149 {
150         void *ret = dma_alloc_coherent(dev, size, dma_handle, flag);
151         if (ret)
152                 memset(ret, 0, size);
153         return ret;
154 }
155
156 extern int __netdev_printk(const char *level, const struct net_device *dev,
157                            struct va_format *vaf);
158
159 #endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(3,2,0)) */
160
161 #endif /* LINUX_3_2_COMPAT_H */