inetpeer: Mark metrics as "new" in fresh inetpeer entries.
authorDavid S. Miller <davem@davemloft.net>
Thu, 27 Jan 2011 21:52:16 +0000 (13:52 -0800)
committerDavid S. Miller <davem@davemloft.net>
Thu, 27 Jan 2011 21:52:16 +0000 (13:52 -0800)
Set the RTAX_LOCKED metric to INETPEER_METRICS_NEW (basically,
all ones) on fresh inetpeer entries.

This way code can determine if default metrics have been loaded
in from a routing table entry already.

Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/inetpeer.h
net/ipv4/inetpeer.c

index 2af0c63d3975252f6c6907b386ee127d38102892..61f2c66edb2a57813e0e553ceb165bab876d2d44 100644 (file)
@@ -51,6 +51,13 @@ struct inet_peer {
 
 void                   inet_initpeers(void) __init;
 
+#define INETPEER_METRICS_NEW   (~(u32) 0)
+
+static inline bool inet_metrics_new(const struct inet_peer *p)
+{
+       return p->metrics[RTAX_LOCK-1] == INETPEER_METRICS_NEW;
+}
+
 /* can be called with or without local BH being disabled */
 struct inet_peer       *inet_getpeer(struct inetpeer_addr *daddr, int create);
 
index a96e65674ac3e694e8e70fec1855324a694ccbf3..b6513b13d7297834d60c3faf6cd94c5c056a331e 100644 (file)
@@ -512,6 +512,7 @@ struct inet_peer *inet_getpeer(struct inetpeer_addr *daddr, int create)
                atomic_set(&p->rid, 0);
                atomic_set(&p->ip_id_count, secure_ip_id(daddr->a4));
                p->tcp_ts_stamp = 0;
+               p->metrics[RTAX_LOCK-1] = INETPEER_METRICS_NEW;
                INIT_LIST_HEAD(&p->unused);