diff options
author | Benjamin Thery <benjamin.thery@bull.net> | 2007-10-08 23:39:36 -0400 |
---|---|---|
committer | David S. Miller <davem@sunset.davemloft.net> | 2007-10-10 19:54:58 -0400 |
commit | 0a8891a0a419d43ea06c8ded0849f0820c6a873b (patch) | |
tree | c27533cfcb08840470ae082bc981a03d2fa57c22 | |
parent | 4665079cbb2a3e17de82f2ab2940b9f97f37d65e (diff) |
[IPv6]: use container_of() macro in fib6_clean_node()
In ip6_fib.c, fib6_clean_node() casts a fib6_walker_t pointer to
a fib6_cleaner_t pointer assuming a struct fib6_walker_t (field 'w')
is the first field in struct fib6_walker_t.
To prevent any future problems that may occur if one day a field
is inadvertently inserted before the 'w' field in struct fib6_cleaner_t,
(and to improve readability), this patch uses the container_of() macro.
Signed-off-by: Benjamin Thery <benjamin.thery@bull.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/ipv6/ip6_fib.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/ipv6/ip6_fib.c b/net/ipv6/ip6_fib.c index 6a612a701eaa..946cf389ab95 100644 --- a/net/ipv6/ip6_fib.c +++ b/net/ipv6/ip6_fib.c | |||
@@ -1313,7 +1313,7 @@ static int fib6_clean_node(struct fib6_walker_t *w) | |||
1313 | { | 1313 | { |
1314 | int res; | 1314 | int res; |
1315 | struct rt6_info *rt; | 1315 | struct rt6_info *rt; |
1316 | struct fib6_cleaner_t *c = (struct fib6_cleaner_t*)w; | 1316 | struct fib6_cleaner_t *c = container_of(w, struct fib6_cleaner_t, w); |
1317 | 1317 | ||
1318 | for (rt = w->leaf; rt; rt = rt->u.dst.rt6_next) { | 1318 | for (rt = w->leaf; rt; rt = rt->u.dst.rt6_next) { |
1319 | res = c->func(rt, c->arg); | 1319 | res = c->func(rt, c->arg); |