aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/skbuff.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/linux/skbuff.h')
-rw-r--r--include/linux/skbuff.h117
1 files changed, 108 insertions, 9 deletions
diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h
index 9dcf956ad18a..61ce97a8b868 100644
--- a/include/linux/skbuff.h
+++ b/include/linux/skbuff.h
@@ -29,9 +29,6 @@
29#include <linux/dmaengine.h> 29#include <linux/dmaengine.h>
30#include <linux/hrtimer.h> 30#include <linux/hrtimer.h>
31 31
32#define HAVE_ALLOC_SKB /* For the drivers to know */
33#define HAVE_ALIGNABLE_SKB /* Ditto 8) */
34
35/* Don't change this without changing skb_csum_unnecessary! */ 32/* Don't change this without changing skb_csum_unnecessary! */
36#define CHECKSUM_NONE 0 33#define CHECKSUM_NONE 0
37#define CHECKSUM_UNNECESSARY 1 34#define CHECKSUM_UNNECESSARY 1
@@ -135,6 +132,57 @@ struct skb_frag_struct {
135 __u32 size; 132 __u32 size;
136}; 133};
137 134
135#define HAVE_HW_TIME_STAMP
136
137/**
138 * skb_shared_hwtstamps - hardware time stamps
139 *
140 * @hwtstamp: hardware time stamp transformed into duration
141 * since arbitrary point in time
142 * @syststamp: hwtstamp transformed to system time base
143 *
144 * Software time stamps generated by ktime_get_real() are stored in
145 * skb->tstamp. The relation between the different kinds of time
146 * stamps is as follows:
147 *
148 * syststamp and tstamp can be compared against each other in
149 * arbitrary combinations. The accuracy of a
150 * syststamp/tstamp/"syststamp from other device" comparison is
151 * limited by the accuracy of the transformation into system time
152 * base. This depends on the device driver and its underlying
153 * hardware.
154 *
155 * hwtstamps can only be compared against other hwtstamps from
156 * the same device.
157 *
158 * This structure is attached to packets as part of the
159 * &skb_shared_info. Use skb_hwtstamps() to get a pointer.
160 */
161struct skb_shared_hwtstamps {
162 ktime_t hwtstamp;
163 ktime_t syststamp;
164};
165
166/**
167 * skb_shared_tx - instructions for time stamping of outgoing packets
168 *
169 * @hardware: generate hardware time stamp
170 * @software: generate software time stamp
171 * @in_progress: device driver is going to provide
172 * hardware time stamp
173 *
174 * These flags are attached to packets as part of the
175 * &skb_shared_info. Use skb_tx() to get a pointer.
176 */
177union skb_shared_tx {
178 struct {
179 __u8 hardware:1,
180 software:1,
181 in_progress:1;
182 };
183 __u8 flags;
184};
185
138/* This data is invariant across clones and lives at 186/* This data is invariant across clones and lives at
139 * the end of the header data, ie. at skb->end. 187 * the end of the header data, ie. at skb->end.
140 */ 188 */
@@ -146,10 +194,12 @@ struct skb_shared_info {
146 unsigned short gso_segs; 194 unsigned short gso_segs;
147 unsigned short gso_type; 195 unsigned short gso_type;
148 __be32 ip6_frag_id; 196 __be32 ip6_frag_id;
197 union skb_shared_tx tx_flags;
149#ifdef CONFIG_HAS_DMA 198#ifdef CONFIG_HAS_DMA
150 unsigned int num_dma_maps; 199 unsigned int num_dma_maps;
151#endif 200#endif
152 struct sk_buff *frag_list; 201 struct sk_buff *frag_list;
202 struct skb_shared_hwtstamps hwtstamps;
153 skb_frag_t frags[MAX_SKB_FRAGS]; 203 skb_frag_t frags[MAX_SKB_FRAGS];
154#ifdef CONFIG_HAS_DMA 204#ifdef CONFIG_HAS_DMA
155 dma_addr_t dma_maps[MAX_SKB_FRAGS + 1]; 205 dma_addr_t dma_maps[MAX_SKB_FRAGS + 1];
@@ -459,6 +509,16 @@ static inline unsigned char *skb_end_pointer(const struct sk_buff *skb)
459/* Internal */ 509/* Internal */
460#define skb_shinfo(SKB) ((struct skb_shared_info *)(skb_end_pointer(SKB))) 510#define skb_shinfo(SKB) ((struct skb_shared_info *)(skb_end_pointer(SKB)))
461 511
512static inline struct skb_shared_hwtstamps *skb_hwtstamps(struct sk_buff *skb)
513{
514 return &skb_shinfo(skb)->hwtstamps;
515}
516
517static inline union skb_shared_tx *skb_tx(struct sk_buff *skb)
518{
519 return &skb_shinfo(skb)->tx_flags;
520}
521
462/** 522/**
463 * skb_queue_empty - check if a queue is empty 523 * skb_queue_empty - check if a queue is empty
464 * @list: queue head 524 * @list: queue head
@@ -1278,7 +1338,7 @@ static inline int skb_network_offset(const struct sk_buff *skb)
1278 * The networking layer reserves some headroom in skb data (via 1338 * The networking layer reserves some headroom in skb data (via
1279 * dev_alloc_skb). This is used to avoid having to reallocate skb data when 1339 * dev_alloc_skb). This is used to avoid having to reallocate skb data when
1280 * the header has to grow. In the default case, if the header has to grow 1340 * the header has to grow. In the default case, if the header has to grow
1281 * 16 bytes or less we avoid the reallocation. 1341 * 32 bytes or less we avoid the reallocation.
1282 * 1342 *
1283 * Unfortunately this headroom changes the DMA alignment of the resulting 1343 * Unfortunately this headroom changes the DMA alignment of the resulting
1284 * network packet. As for NET_IP_ALIGN, this unaligned DMA is expensive 1344 * network packet. As for NET_IP_ALIGN, this unaligned DMA is expensive
@@ -1286,11 +1346,11 @@ static inline int skb_network_offset(const struct sk_buff *skb)
1286 * perhaps setting it to a cacheline in size (since that will maintain 1346 * perhaps setting it to a cacheline in size (since that will maintain
1287 * cacheline alignment of the DMA). It must be a power of 2. 1347 * cacheline alignment of the DMA). It must be a power of 2.
1288 * 1348 *
1289 * Various parts of the networking layer expect at least 16 bytes of 1349 * Various parts of the networking layer expect at least 32 bytes of
1290 * headroom, you should not reduce this. 1350 * headroom, you should not reduce this.
1291 */ 1351 */
1292#ifndef NET_SKB_PAD 1352#ifndef NET_SKB_PAD
1293#define NET_SKB_PAD 16 1353#define NET_SKB_PAD 32
1294#endif 1354#endif
1295 1355
1296extern int ___pskb_trim(struct sk_buff *skb, unsigned int len); 1356extern int ___pskb_trim(struct sk_buff *skb, unsigned int len);
@@ -1678,8 +1738,6 @@ extern int skb_shift(struct sk_buff *tgt, struct sk_buff *skb,
1678 int shiftlen); 1738 int shiftlen);
1679 1739
1680extern struct sk_buff *skb_segment(struct sk_buff *skb, int features); 1740extern struct sk_buff *skb_segment(struct sk_buff *skb, int features);
1681extern int skb_gro_receive(struct sk_buff **head,
1682 struct sk_buff *skb);
1683 1741
1684static inline void *skb_header_pointer(const struct sk_buff *skb, int offset, 1742static inline void *skb_header_pointer(const struct sk_buff *skb, int offset,
1685 int len, void *buffer) 1743 int len, void *buffer)
@@ -1726,6 +1784,11 @@ static inline void skb_copy_to_linear_data_offset(struct sk_buff *skb,
1726 1784
1727extern void skb_init(void); 1785extern void skb_init(void);
1728 1786
1787static inline ktime_t skb_get_ktime(const struct sk_buff *skb)
1788{
1789 return skb->tstamp;
1790}
1791
1729/** 1792/**
1730 * skb_get_timestamp - get timestamp from a skb 1793 * skb_get_timestamp - get timestamp from a skb
1731 * @skb: skb to get stamp from 1794 * @skb: skb to get stamp from
@@ -1735,11 +1798,18 @@ extern void skb_init(void);
1735 * This function converts the offset back to a struct timeval and stores 1798 * This function converts the offset back to a struct timeval and stores
1736 * it in stamp. 1799 * it in stamp.
1737 */ 1800 */
1738static inline void skb_get_timestamp(const struct sk_buff *skb, struct timeval *stamp) 1801static inline void skb_get_timestamp(const struct sk_buff *skb,
1802 struct timeval *stamp)
1739{ 1803{
1740 *stamp = ktime_to_timeval(skb->tstamp); 1804 *stamp = ktime_to_timeval(skb->tstamp);
1741} 1805}
1742 1806
1807static inline void skb_get_timestampns(const struct sk_buff *skb,
1808 struct timespec *stamp)
1809{
1810 *stamp = ktime_to_timespec(skb->tstamp);
1811}
1812
1743static inline void __net_timestamp(struct sk_buff *skb) 1813static inline void __net_timestamp(struct sk_buff *skb)
1744{ 1814{
1745 skb->tstamp = ktime_get_real(); 1815 skb->tstamp = ktime_get_real();
@@ -1755,6 +1825,20 @@ static inline ktime_t net_invalid_timestamp(void)
1755 return ktime_set(0, 0); 1825 return ktime_set(0, 0);
1756} 1826}
1757 1827
1828/**
1829 * skb_tstamp_tx - queue clone of skb with send time stamps
1830 * @orig_skb: the original outgoing packet
1831 * @hwtstamps: hardware time stamps, may be NULL if not available
1832 *
1833 * If the skb has a socket associated, then this function clones the
1834 * skb (thus sharing the actual data and optional structures), stores
1835 * the optional hardware time stamping information (if non NULL) or
1836 * generates a software time stamp (otherwise), then queues the clone
1837 * to the error queue of the socket. Errors are silently ignored.
1838 */
1839extern void skb_tstamp_tx(struct sk_buff *orig_skb,
1840 struct skb_shared_hwtstamps *hwtstamps);
1841
1758extern __sum16 __skb_checksum_complete_head(struct sk_buff *skb, int len); 1842extern __sum16 __skb_checksum_complete_head(struct sk_buff *skb, int len);
1759extern __sum16 __skb_checksum_complete(struct sk_buff *skb); 1843extern __sum16 __skb_checksum_complete(struct sk_buff *skb);
1760 1844
@@ -1895,6 +1979,21 @@ static inline void skb_copy_queue_mapping(struct sk_buff *to, const struct sk_bu
1895 to->queue_mapping = from->queue_mapping; 1979 to->queue_mapping = from->queue_mapping;
1896} 1980}
1897 1981
1982static inline void skb_record_rx_queue(struct sk_buff *skb, u16 rx_queue)
1983{
1984 skb->queue_mapping = rx_queue + 1;
1985}
1986
1987static inline u16 skb_get_rx_queue(struct sk_buff *skb)
1988{
1989 return skb->queue_mapping - 1;
1990}
1991
1992static inline bool skb_rx_queue_recorded(struct sk_buff *skb)
1993{
1994 return (skb->queue_mapping != 0);
1995}
1996
1898#ifdef CONFIG_XFRM 1997#ifdef CONFIG_XFRM
1899static inline struct sec_path *skb_sec_path(struct sk_buff *skb) 1998static inline struct sec_path *skb_sec_path(struct sk_buff *skb)
1900{ 1999{