aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStephen Hemminger <shemminger@vyatta.com>2008-06-03 16:03:15 -0700
committerDavid S. Miller <davem@davemloft.net>2008-06-03 16:03:15 -0700
commitb9f5f52cca3e94f1e7509f366aa250ebbe1ed0b5 (patch)
tree539f26976e4f44f24d230357de75772ae5a4df3b
parent57c511d8d47caeeae375cb8106662c0bd6a7e7e0 (diff)
downloadkernel_samsung_smdk4412-b9f5f52cca3e94f1e7509f366aa250ebbe1ed0b5.tar.gz
kernel_samsung_smdk4412-b9f5f52cca3e94f1e7509f366aa250ebbe1ed0b5.tar.bz2
kernel_samsung_smdk4412-b9f5f52cca3e94f1e7509f366aa250ebbe1ed0b5.zip
net: neighbour table ABI problem
The neighbor table time of last use information is returned in the incorrect unit. Kernel to user space ABI's need to use USER_HZ (or milliseconds), otherwise the application has to try and discover the real system HZ value which is problematic. Linux has standardized on keeping USER_HZ consistent (100hz) even when kernel is running internally at some other value. This change is small, but it breaks the ABI for older version of iproute2 utilities. But these utilities are already broken since they are looking at the psched_hz values which are completely different. So let's just go ahead and fix both kernel and user space. Older utilities will just print wrong values. Signed-off-by: Stephen Hemminger <shemminger@vyatta.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--net/core/neighbour.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/net/core/neighbour.c b/net/core/neighbour.c
index 5d9d7130bd6..3896de79dfb 100644
--- a/net/core/neighbour.c
+++ b/net/core/neighbour.c
@@ -2057,9 +2057,9 @@ static int neigh_fill_info(struct sk_buff *skb, struct neighbour *neigh,
goto nla_put_failure;
}
- ci.ndm_used = now - neigh->used;
- ci.ndm_confirmed = now - neigh->confirmed;
- ci.ndm_updated = now - neigh->updated;
+ ci.ndm_used = jiffies_to_clock_t(now - neigh->used);
+ ci.ndm_confirmed = jiffies_to_clock_t(now - neigh->confirmed);
+ ci.ndm_updated = jiffies_to_clock_t(now - neigh->updated);
ci.ndm_refcnt = atomic_read(&neigh->refcnt) - 1;
read_unlock_bh(&neigh->lock);