mirror of
https://github.com/adulau/aha.git
synced 2024-12-28 19:56:18 +00:00
[INET]: Add missed tunnel64_err handler
The tunnel64_protocol uses the tunnel4_protocol's err_handler and thus calls the tunnel4_protocol's handlers. This is not very good, as in case of (icmp) error the wrong error handlers will be called (e.g. ipip ones instead of sit) and this won't be noticed at all, because the error is not reported. Signed-off-by: Pavel Emelyanov <xemul@openvz.org> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
c2b42336f4
commit
99f933263a
1 changed files with 12 additions and 1 deletions
|
@ -118,6 +118,17 @@ static void tunnel4_err(struct sk_buff *skb, u32 info)
|
|||
break;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE)
|
||||
static void tunnel64_err(struct sk_buff *skb, u32 info)
|
||||
{
|
||||
struct xfrm_tunnel *handler;
|
||||
|
||||
for (handler = tunnel64_handlers; handler; handler = handler->next)
|
||||
if (!handler->err_handler(skb, info))
|
||||
break;
|
||||
}
|
||||
#endif
|
||||
|
||||
static struct net_protocol tunnel4_protocol = {
|
||||
.handler = tunnel4_rcv,
|
||||
.err_handler = tunnel4_err,
|
||||
|
@ -127,7 +138,7 @@ static struct net_protocol tunnel4_protocol = {
|
|||
#if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE)
|
||||
static struct net_protocol tunnel64_protocol = {
|
||||
.handler = tunnel64_rcv,
|
||||
.err_handler = tunnel4_err,
|
||||
.err_handler = tunnel64_err,
|
||||
.no_policy = 1,
|
||||
};
|
||||
#endif
|
||||
|
|
Loading…
Reference in a new issue