1 #ifndef LINUX_3_2_COMPAT_H
2 #define LINUX_3_2_COMPAT_H
4 #include <linux/version.h>
6 #if (LINUX_VERSION_CODE < KERNEL_VERSION(3,2,0))
8 #include <linux/skbuff.h>
9 #include <linux/dma-mapping.h>
10 #include <linux/ethtool.h>
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 */
16 #define PMSG_IS_AUTO(msg) (((msg).event & PM_EVENT_AUTO) != 0)
18 extern int __ethtool_get_settings(struct net_device *dev,
19 struct ethtool_cmd *cmd);
22 * skb_frag_page - retrieve the page refered to by a paged fragment
23 * @frag: the paged fragment
25 * Returns the &struct page associated with @frag.
27 #define skb_frag_page LINUX_BACKPORT(skb_frag_page)
28 static inline struct page *skb_frag_page(const skb_frag_t *frag)
34 * __skb_frag_set_page - sets the page contained in a paged fragment
35 * @frag: the paged fragment
36 * @page: the page to set
38 * Sets the fragment @frag to contain @page.
40 #define __skb_frag_set_page LINUX_BACKPORT(__skb_frag_set_page)
41 static inline void __skb_frag_set_page(skb_frag_t *frag, struct page *page)
47 * skb_frag_set_page - sets the page contained in a paged fragment of an skb
49 * @f: the fragment offset
50 * @page: the page to set
52 * Sets the @f'th fragment of @skb to contain @page.
54 #define skb_frag_set_page LINUX_BACKPORT(skb_frag_set_page)
55 static inline void skb_frag_set_page(struct sk_buff *skb, int f,
58 __skb_frag_set_page(&skb_shinfo(skb)->frags[f], page);
62 * skb_frag_address_safe - gets the address of the data contained in a paged fragment
63 * @frag: the paged fragment buffer
65 * Returns the address of the data within @frag. Checks that the page
66 * is mapped and returns %NULL otherwise.
68 #define skb_frag_address_safe LINUX_BACKPORT(skb_frag_address_safe)
69 static inline void *skb_frag_address_safe(const skb_frag_t *frag)
71 void *ptr = page_address(skb_frag_page(frag));
75 return ptr + frag->page_offset;
79 * skb_frag_dma_map - maps a paged fragment via the DMA API
80 * @device: the device to map the fragment to
81 * @frag: the paged fragment to map
82 * @offset: the offset within the fragment (starting at the
83 * fragment's own offset)
84 * @size: the number of bytes to map
85 * @direction: the direction of the mapping (%PCI_DMA_*)
87 * Maps the page associated with @frag to @device.
89 #define skb_frag_dma_map LINUX_BACKPORT(skb_frag_dma_map)
90 static inline dma_addr_t skb_frag_dma_map(struct device *dev,
91 const skb_frag_t *frag,
92 size_t offset, size_t size,
93 enum dma_data_direction dir)
95 return dma_map_page(dev, skb_frag_page(frag),
96 frag->page_offset + offset, size, dir);
100 * __skb_frag_unref - release a reference on a paged fragment.
101 * @frag: the paged fragment
103 * Releases a reference on the paged fragment @frag.
105 #define __skb_frag_unref LINUX_BACKPORT(__skb_frag_unref)
106 static inline void __skb_frag_unref(skb_frag_t *frag)
108 put_page(skb_frag_page(frag));
111 #define ETH_P_TDLS 0x890D /* TDLS */
113 #define skb_frag_size LINUX_BACKPORT(skb_frag_size)
114 static inline unsigned int skb_frag_size(const skb_frag_t *frag)
119 #define skb_frag_size_set LINUX_BACKPORT(skb_frag_size_set)
120 static inline void skb_frag_size_set(skb_frag_t *frag, unsigned int size)
125 #define skb_frag_size_add LINUX_BACKPORT(skb_frag_size_add)
126 static inline void skb_frag_size_add(skb_frag_t *frag, int delta)
131 #define skb_frag_size_sub LINUX_BACKPORT(skb_frag_size_sub)
132 static inline void skb_frag_size_sub(skb_frag_t *frag, int delta)
137 #define hex_byte_pack LINUX_BACKPORT(hex_byte_pack)
138 static inline char *hex_byte_pack(char *buf, u8 byte)
140 *buf++ = hex_asc_hi(byte);
141 *buf++ = hex_asc_lo(byte);
145 /* module_platform_driver() - Helper macro for drivers that don't do
146 * anything special in module init/exit. This eliminates a lot of
147 * boilerplate. Each module may only use this macro once, and
148 * calling it replaces module_init() and module_exit()
150 #define module_platform_driver(__platform_driver) \
151 module_driver(__platform_driver, platform_driver_register, \
152 platform_driver_unregister)
154 #define dma_zalloc_coherent LINUX_BACKPORT(dma_zalloc_coherent)
155 static inline void *dma_zalloc_coherent(struct device *dev, size_t size,
156 dma_addr_t *dma_handle, gfp_t flag)
158 void *ret = dma_alloc_coherent(dev, size, dma_handle, flag);
160 memset(ret, 0, size);
164 #define __netdev_printk LINUX_BACKPORT(__netdev_printk)
165 extern int __netdev_printk(const char *level, const struct net_device *dev,
166 struct va_format *vaf);
167 #ifndef IFF_UNICAST_FLT
168 #define IFF_UNICAST_FLT 0x20000 /* Supports unicast filtering */
171 #endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(3,2,0)) */
173 #endif /* LINUX_3_2_COMPAT_H */