diff options
author | Eric Dumazet <dada1@cosmosbay.com> | 2007-04-19 19:16:32 -0400 |
---|---|---|
committer | David S. Miller <davem@sunset.davemloft.net> | 2007-04-26 01:23:34 -0400 |
commit | b7aa0bf70c4afb9e38be25f5c0922498d0f8684c (patch) | |
tree | 4bc9d61031f4eb40d73887d6bde09e7d6bf2b259 /include/linux | |
parent | 3927f2e8f9afa3424bb51ca81f7abac01ffd0005 (diff) |
[NET]: convert network timestamps to ktime_t
We currently use a special structure (struct skb_timeval) and plain
'struct timeval' to store packet timestamps in sk_buffs and struct
sock.
This has some drawbacks :
- Fixed resolution of micro second.
- Waste of space on 64bit platforms where sizeof(struct timeval)=16
I suggest using ktime_t that is a nice abstraction of high resolution
time services, currently capable of nanosecond resolution.
As sizeof(ktime_t) is 8 bytes, using ktime_t in 'struct sock' permits
a 8 byte shrink of this structure on 64bit architectures. Some other
structures also benefit from this size reduction (struct ipq in
ipv4/ip_fragment.c, struct frag_queue in ipv6/reassembly.c, ...)
Once this ktime infrastructure adopted, we can more easily provide
nanosecond resolution on top of it. (ioctl SIOCGSTAMPNS and/or
SO_TIMESTAMPNS/SCM_TIMESTAMPNS)
Note : this patch includes a bug correction in
compat_sock_get_timestamp() where a "err = 0;" was missing (so this
syscall returned -ENOENT instead of 0)
Signed-off-by: Eric Dumazet <dada1@cosmosbay.com>
CC: Stephen Hemminger <shemminger@linux-foundation.org>
CC: John find <linux.kernel@free.fr>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/skbuff.h | 26 |
1 files changed, 5 insertions, 21 deletions
diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h index 5992f65b4184..f9441b5f8d13 100644 --- a/include/linux/skbuff.h +++ b/include/linux/skbuff.h | |||
@@ -27,6 +27,7 @@ | |||
27 | #include <net/checksum.h> | 27 | #include <net/checksum.h> |
28 | #include <linux/rcupdate.h> | 28 | #include <linux/rcupdate.h> |
29 | #include <linux/dmaengine.h> | 29 | #include <linux/dmaengine.h> |
30 | #include <linux/hrtimer.h> | ||
30 | 31 | ||
31 | #define HAVE_ALLOC_SKB /* For the drivers to know */ | 32 | #define HAVE_ALLOC_SKB /* For the drivers to know */ |
32 | #define HAVE_ALIGNABLE_SKB /* Ditto 8) */ | 33 | #define HAVE_ALIGNABLE_SKB /* Ditto 8) */ |
@@ -156,11 +157,6 @@ struct skb_shared_info { | |||
156 | #define SKB_DATAREF_SHIFT 16 | 157 | #define SKB_DATAREF_SHIFT 16 |
157 | #define SKB_DATAREF_MASK ((1 << SKB_DATAREF_SHIFT) - 1) | 158 | #define SKB_DATAREF_MASK ((1 << SKB_DATAREF_SHIFT) - 1) |
158 | 159 | ||
159 | struct skb_timeval { | ||
160 | u32 off_sec; | ||
161 | u32 off_usec; | ||
162 | }; | ||
163 | |||
164 | 160 | ||
165 | enum { | 161 | enum { |
166 | SKB_FCLONE_UNAVAILABLE, | 162 | SKB_FCLONE_UNAVAILABLE, |
@@ -233,7 +229,7 @@ struct sk_buff { | |||
233 | struct sk_buff *prev; | 229 | struct sk_buff *prev; |
234 | 230 | ||
235 | struct sock *sk; | 231 | struct sock *sk; |
236 | struct skb_timeval tstamp; | 232 | ktime_t tstamp; |
237 | struct net_device *dev; | 233 | struct net_device *dev; |
238 | int iif; | 234 | int iif; |
239 | /* 4 byte hole on 64 bit*/ | 235 | /* 4 byte hole on 64 bit*/ |
@@ -1365,26 +1361,14 @@ extern void skb_add_mtu(int mtu); | |||
1365 | */ | 1361 | */ |
1366 | static inline void skb_get_timestamp(const struct sk_buff *skb, struct timeval *stamp) | 1362 | static inline void skb_get_timestamp(const struct sk_buff *skb, struct timeval *stamp) |
1367 | { | 1363 | { |
1368 | stamp->tv_sec = skb->tstamp.off_sec; | 1364 | *stamp = ktime_to_timeval(skb->tstamp); |
1369 | stamp->tv_usec = skb->tstamp.off_usec; | ||
1370 | } | 1365 | } |
1371 | 1366 | ||
1372 | /** | 1367 | static inline void __net_timestamp(struct sk_buff *skb) |
1373 | * skb_set_timestamp - set timestamp of a skb | ||
1374 | * @skb: skb to set stamp of | ||
1375 | * @stamp: pointer to struct timeval to get stamp from | ||
1376 | * | ||
1377 | * Timestamps are stored in the skb as offsets to a base timestamp. | ||
1378 | * This function converts a struct timeval to an offset and stores | ||
1379 | * it in the skb. | ||
1380 | */ | ||
1381 | static inline void skb_set_timestamp(struct sk_buff *skb, const struct timeval *stamp) | ||
1382 | { | 1368 | { |
1383 | skb->tstamp.off_sec = stamp->tv_sec; | 1369 | skb->tstamp = ktime_get_real(); |
1384 | skb->tstamp.off_usec = stamp->tv_usec; | ||
1385 | } | 1370 | } |
1386 | 1371 | ||
1387 | extern void __net_timestamp(struct sk_buff *skb); | ||
1388 | 1372 | ||
1389 | extern __sum16 __skb_checksum_complete(struct sk_buff *skb); | 1373 | extern __sum16 __skb_checksum_complete(struct sk_buff *skb); |
1390 | 1374 | ||