aboutsummaryrefslogtreecommitdiffstats
path: root/include/net/neighbour.h
diff options
context:
space:
mode:
authorDavid Miller <davem@davemloft.net>2011-07-25 00:01:17 +0000
committerDavid S. Miller <davem@davemloft.net>2011-11-30 18:46:43 -0500
commit1026fec8739663621d64216ba939c23bc1d089b7 (patch)
treed8ba40edf7952d1c2fa2b832fdfceeb537fcb145 /include/net/neighbour.h
parent449fa023bca5b53bd924d91a27ffd34807fdeb80 (diff)
downloadkernel_goldelico_gta04-1026fec8739663621d64216ba939c23bc1d089b7.zip
kernel_goldelico_gta04-1026fec8739663621d64216ba939c23bc1d089b7.tar.gz
kernel_goldelico_gta04-1026fec8739663621d64216ba939c23bc1d089b7.tar.bz2
neigh: Create mechanism for generic neigh private areas.
The implementation private sits right after the primary_key memory. Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/net/neighbour.h')
-rw-r--r--include/net/neighbour.h7
1 files changed, 7 insertions, 0 deletions
diff --git a/include/net/neighbour.h b/include/net/neighbour.h
index 7ae5acf..87c0e5c 100644
--- a/include/net/neighbour.h
+++ b/include/net/neighbour.h
@@ -179,6 +179,13 @@ struct neigh_table {
struct pneigh_entry **phash_buckets;
};
+#define NEIGH_PRIV_ALIGN sizeof(long long)
+
+static inline void *neighbour_priv(const struct neighbour *n)
+{
+ return (char *)n + ALIGN(sizeof(*n) + n->tbl->key_len, NEIGH_PRIV_ALIGN);
+}
+
/* flags for neigh_update() */
#define NEIGH_UPDATE_F_OVERRIDE 0x00000001
#define NEIGH_UPDATE_F_WEAK_OVERRIDE 0x00000002