* [PATCH] [IPv4] Reply net unreachable ICMP message
@ 2007-12-06 6:31 Mitsuru Chinen
2007-12-06 6:33 ` David Miller
2007-12-06 7:49 ` Jarek Poplawski
0 siblings, 2 replies; 7+ messages in thread
From: Mitsuru Chinen @ 2007-12-06 6:31 UTC (permalink / raw)
To: netdev; +Cc: David Miller
IPv4 stack doesn't reply any ICMP destination unreachable message
with net unreachable code when IP detagrams are being discarded
because of no route could be found in the forwarding path.
Incidentally, IPv6 stack replies such ICMPv6 message in the similar
situation.
Signed-off-by: Mitsuru Chinen <mitch@linux.vnet.ibm.com>
---
net/ipv4/route.c | 2 ++
1 files changed, 2 insertions(+), 0 deletions(-)
diff --git a/net/ipv4/route.c b/net/ipv4/route.c
index 6714bbc..ba85ec9 100644
--- a/net/ipv4/route.c
+++ b/net/ipv4/route.c
@@ -1375,6 +1375,7 @@ static int ip_error(struct sk_buff *skb)
break;
case ENETUNREACH:
code = ICMP_NET_UNREACH;
+ IP_INC_STATS_BH(IPSTATS_MIB_INNOROUTES);
break;
case EACCES:
code = ICMP_PKT_FILTERED;
@@ -2004,6 +2005,7 @@ no_route:
RT_CACHE_STAT_INC(in_no_route);
spec_dst = inet_select_addr(dev, 0, RT_SCOPE_UNIVERSE);
res.type = RTN_UNREACHABLE;
+ err = -ENETUNREACH;
goto local_input;
/*
--
1.5.3.4
^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCH] [IPv4] Reply net unreachable ICMP message
2007-12-06 6:31 [PATCH] [IPv4] Reply net unreachable ICMP message Mitsuru Chinen
@ 2007-12-06 6:33 ` David Miller
2007-12-06 7:49 ` Jarek Poplawski
1 sibling, 0 replies; 7+ messages in thread
From: David Miller @ 2007-12-06 6:33 UTC (permalink / raw)
To: mitch; +Cc: netdev
From: Mitsuru Chinen <mitch@linux.vnet.ibm.com>
Date: Thu, 6 Dec 2007 15:31:05 +0900
> IPv4 stack doesn't reply any ICMP destination unreachable message
> with net unreachable code when IP detagrams are being discarded
> because of no route could be found in the forwarding path.
> Incidentally, IPv6 stack replies such ICMPv6 message in the similar
> situation.
>
> Signed-off-by: Mitsuru Chinen <mitch@linux.vnet.ibm.com>
Also applied, thank you.
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] [IPv4] Reply net unreachable ICMP message
2007-12-06 6:31 [PATCH] [IPv4] Reply net unreachable ICMP message Mitsuru Chinen
2007-12-06 6:33 ` David Miller
@ 2007-12-06 7:49 ` Jarek Poplawski
2007-12-06 8:12 ` Rami Rosen
2007-12-06 8:14 ` Mitsuru Chinen
1 sibling, 2 replies; 7+ messages in thread
From: Jarek Poplawski @ 2007-12-06 7:49 UTC (permalink / raw)
To: Mitsuru Chinen; +Cc: netdev, David Miller
On 06-12-2007 07:31, Mitsuru Chinen wrote:
> IPv4 stack doesn't reply any ICMP destination unreachable message
> with net unreachable code when IP detagrams are being discarded
> because of no route could be found in the forwarding path.
> Incidentally, IPv6 stack replies such ICMPv6 message in the similar
> situation.
>
> Signed-off-by: Mitsuru Chinen <mitch@linux.vnet.ibm.com>
> ---
> net/ipv4/route.c | 2 ++
> 1 files changed, 2 insertions(+), 0 deletions(-)
>
> diff --git a/net/ipv4/route.c b/net/ipv4/route.c
> index 6714bbc..ba85ec9 100644
> --- a/net/ipv4/route.c
> +++ b/net/ipv4/route.c
> @@ -1375,6 +1375,7 @@ static int ip_error(struct sk_buff *skb)
> break;
> case ENETUNREACH:
> code = ICMP_NET_UNREACH;
> + IP_INC_STATS_BH(IPSTATS_MIB_INNOROUTES);
> break;
> case EACCES:
> code = ICMP_PKT_FILTERED;
> @@ -2004,6 +2005,7 @@ no_route:
> RT_CACHE_STAT_INC(in_no_route);
> spec_dst = inet_select_addr(dev, 0, RT_SCOPE_UNIVERSE);
> res.type = RTN_UNREACHABLE;
> + err = -ENETUNREACH;
> goto local_input;
>
> /*
This patch seems to be wrong. It overrides err codes from
fib_lookup, where such decisions should be made.
Regards,
Jarek P.
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] [IPv4] Reply net unreachable ICMP message
2007-12-06 7:49 ` Jarek Poplawski
@ 2007-12-06 8:12 ` Rami Rosen
2007-12-06 8:14 ` Mitsuru Chinen
1 sibling, 0 replies; 7+ messages in thread
From: Rami Rosen @ 2007-12-06 8:12 UTC (permalink / raw)
To: Jarek Poplawski; +Cc: Mitsuru Chinen, netdev, David Miller
Hello, Jarek,
I am sorry, but I think I am nor sure I underatand exactly what you mean when
you say:
"It overrides err codes from fib_lookup, where such decisions should be made."
What is incorrect here ?
There are two lines added in this patch;
IP_INC_STATS_BH(IPSTATS_MIB_INNOROUTES);
and err = -ENETUNREACH;
The first one is, regardless to say, not relevant to err codes.
The second, err = -ENETUNREACH, is from: ip_route_input_slow().
(net/ipv4/route.c).
Assigning values to err is done more than once in this method;
for example,
e_hostunreach:
err = -EHOSTUNREACH;
e_inval:
err = -EINVAL;
e_nobufs:
err = -ENOBUFS;
So I don't think anything is incorrect here.
Regards,
Rami Rosen
On Dec 6, 2007 9:49 AM, Jarek Poplawski <jarkao2@o2.pl> wrote:
>
> On 06-12-2007 07:31, Mitsuru Chinen wrote:
> > IPv4 stack doesn't reply any ICMP destination unreachable message
> > with net unreachable code when IP detagrams are being discarded
> > because of no route could be found in the forwarding path.
> > Incidentally, IPv6 stack replies such ICMPv6 message in the similar
> > situation.
> >
> > Signed-off-by: Mitsuru Chinen <mitch@linux.vnet.ibm.com>
> > ---
> > net/ipv4/route.c | 2 ++
> > 1 files changed, 2 insertions(+), 0 deletions(-)
> >
> > diff --git a/net/ipv4/route.c b/net/ipv4/route.c
> > index 6714bbc..ba85ec9 100644
> > --- a/net/ipv4/route.c
> > +++ b/net/ipv4/route.c
> > @@ -1375,6 +1375,7 @@ static int ip_error(struct sk_buff *skb)
> > break;
> > case ENETUNREACH:
> > code = ICMP_NET_UNREACH;
> > + IP_INC_STATS_BH(IPSTATS_MIB_INNOROUTES);
> > break;
> > case EACCES:
> > code = ICMP_PKT_FILTERED;
> > @@ -2004,6 +2005,7 @@ no_route:
> > RT_CACHE_STAT_INC(in_no_route);
> > spec_dst = inet_select_addr(dev, 0, RT_SCOPE_UNIVERSE);
> > res.type = RTN_UNREACHABLE;
> > + err = -ENETUNREACH;
> > goto local_input;
> >
> > /*
>
> This patch seems to be wrong. It overrides err codes from
> fib_lookup, where such decisions should be made.
>
> Regards,
> Jarek P.
>
> --
> To unsubscribe from this list: send the line "unsubscribe netdev" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
>
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] [IPv4] Reply net unreachable ICMP message
2007-12-06 7:49 ` Jarek Poplawski
2007-12-06 8:12 ` Rami Rosen
@ 2007-12-06 8:14 ` Mitsuru Chinen
2007-12-06 8:47 ` Jarek Poplawski
1 sibling, 1 reply; 7+ messages in thread
From: Mitsuru Chinen @ 2007-12-06 8:14 UTC (permalink / raw)
To: Jarek Poplawski; +Cc: Jarek Poplawski, netdev, David Miller
On Thu, 6 Dec 2007 08:49:47 +0100
Jarek Poplawski <jarkao2@o2.pl> wrote:
> On 06-12-2007 07:31, Mitsuru Chinen wrote:
> > IPv4 stack doesn't reply any ICMP destination unreachable message
> > with net unreachable code when IP detagrams are being discarded
> > because of no route could be found in the forwarding path.
> > Incidentally, IPv6 stack replies such ICMPv6 message in the similar
> > situation.
> >
> > Signed-off-by: Mitsuru Chinen <mitch@linux.vnet.ibm.com>
> > ---
> > net/ipv4/route.c | 2 ++
> > 1 files changed, 2 insertions(+), 0 deletions(-)
> >
> > diff --git a/net/ipv4/route.c b/net/ipv4/route.c
> > index 6714bbc..ba85ec9 100644
> > --- a/net/ipv4/route.c
> > +++ b/net/ipv4/route.c
> > @@ -1375,6 +1375,7 @@ static int ip_error(struct sk_buff *skb)
> > break;
> > case ENETUNREACH:
> > code = ICMP_NET_UNREACH;
> > + IP_INC_STATS_BH(IPSTATS_MIB_INNOROUTES);
> > break;
> > case EACCES:
> > code = ICMP_PKT_FILTERED;
> > @@ -2004,6 +2005,7 @@ no_route:
> > RT_CACHE_STAT_INC(in_no_route);
> > spec_dst = inet_select_addr(dev, 0, RT_SCOPE_UNIVERSE);
> > res.type = RTN_UNREACHABLE;
> > + err = -ENETUNREACH;
> > goto local_input;
> >
> > /*
>
> This patch seems to be wrong. It overrides err codes from
> fib_lookup, where such decisions should be made.
fib_lookup() replies -ESRCH in this situation.
It is necessary to override the variable by the suitable error
number like the code under e_hostunreach label.
Best Regards,
----
Mitsuru Chinen <mitch@linux.vnet.ibm.com>
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] [IPv4] Reply net unreachable ICMP message
2007-12-06 8:14 ` Mitsuru Chinen
@ 2007-12-06 8:47 ` Jarek Poplawski
2007-12-07 4:23 ` Mitsuru Chinen
0 siblings, 1 reply; 7+ messages in thread
From: Jarek Poplawski @ 2007-12-06 8:47 UTC (permalink / raw)
To: Mitsuru Chinen; +Cc: netdev, David Miller, Rami Rosen
On 06-12-2007 09:14, Mitsuru Chinen wrote:
> On Thu, 6 Dec 2007 08:49:47 +0100
> Jarek Poplawski <jarkao2@o2.pl> wrote:
>
>> On 06-12-2007 07:31, Mitsuru Chinen wrote:
>>> IPv4 stack doesn't reply any ICMP destination unreachable message
>>> with net unreachable code when IP detagrams are being discarded
>>> because of no route could be found in the forwarding path.
>>> Incidentally, IPv6 stack replies such ICMPv6 message in the similar
>>> situation.
...
>> This patch seems to be wrong. It overrides err codes from
>> fib_lookup, where such decisions should be made.
>
> fib_lookup() replies -ESRCH in this situation.
> It is necessary to override the variable by the suitable error
> number like the code under e_hostunreach label.
Probably I miss something, but I can't see how can you be sure it's
only -ESRCH possible here? Isn't opt->action() in fib_rules_lookup()
supposed to return this -ENETUNREACH when needed?
Jarek P.
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] [IPv4] Reply net unreachable ICMP message
2007-12-06 8:47 ` Jarek Poplawski
@ 2007-12-07 4:23 ` Mitsuru Chinen
0 siblings, 0 replies; 7+ messages in thread
From: Mitsuru Chinen @ 2007-12-07 4:23 UTC (permalink / raw)
To: Jarek Poplawski; +Cc: Jarek Poplawski, netdev, David Miller, Rami Rosen
On Thu, 6 Dec 2007 09:47:33 +0100
Jarek Poplawski <jarkao2@o2.pl> wrote:
> On 06-12-2007 09:14, Mitsuru Chinen wrote:
> > On Thu, 6 Dec 2007 08:49:47 +0100
> > Jarek Poplawski <jarkao2@o2.pl> wrote:
> >
> >> On 06-12-2007 07:31, Mitsuru Chinen wrote:
> >>> IPv4 stack doesn't reply any ICMP destination unreachable message
> >>> with net unreachable code when IP detagrams are being discarded
> >>> because of no route could be found in the forwarding path.
> >>> Incidentally, IPv6 stack replies such ICMPv6 message in the similar
> >>> situation.
> ...
> >> This patch seems to be wrong. It overrides err codes from
> >> fib_lookup, where such decisions should be made.
> >
> > fib_lookup() replies -ESRCH in this situation.
> > It is necessary to override the variable by the suitable error
> > number like the code under e_hostunreach label.
>
> Probably I miss something, but I can't see how can you be sure it's
> only -ESRCH possible here? Isn't opt->action() in fib_rules_lookup()
> supposed to return this -ENETUNREACH when needed?
Oh, excuse me. I did mistake.
fib_rules_lookup() replies -ESRCH when no route is found. The case
it replies -ENETUNREACH is that user adds unreachable route.
However, if the err value is override with no check, a blackhole
or prohibit route is treated as a unreachable route.
As the patch is already applied, I will send another patch to add
a check for it.
Thank you very much for pointing out the issue!
Best Regards,
----
Mitsuru Chinen <mitch@linux.vnet.ibm.com>
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2007-12-07 4:24 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-12-06 6:31 [PATCH] [IPv4] Reply net unreachable ICMP message Mitsuru Chinen
2007-12-06 6:33 ` David Miller
2007-12-06 7:49 ` Jarek Poplawski
2007-12-06 8:12 ` Rami Rosen
2007-12-06 8:14 ` Mitsuru Chinen
2007-12-06 8:47 ` Jarek Poplawski
2007-12-07 4:23 ` Mitsuru Chinen
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).