* IP Fragmentation
@ 2003-03-30 21:06 Peteris Krumins
2003-03-31 18:41 ` Daniel F. Chief Security Engineer -
0 siblings, 1 reply; 6+ messages in thread
From: Peteris Krumins @ 2003-03-30 21:06 UTC (permalink / raw)
To: netfilter
Hi,
How often does IP Fragmentation occur?
Is it safe to restrict any fragmented packets to 'come' into my
network?
P.Krumins
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: IP Fragmentation
2003-03-30 21:06 IP Fragmentation Peteris Krumins
@ 2003-03-31 18:41 ` Daniel F. Chief Security Engineer -
0 siblings, 0 replies; 6+ messages in thread
From: Daniel F. Chief Security Engineer - @ 2003-03-31 18:41 UTC (permalink / raw)
To: Peteris Krumins, netfilter
Depends on your network and weather or not you care to be rfc compliant.
I see real fragmented traffic all the time. I choose not to block it. Because
it would break stuff that our customers need to use. So i just keep an eye on
fragmentation and watch fro abuse of it. We host 125,000 web sites, and use
iptables on our Firewalls (8).
On Sunday 30 March 2003 15:06, Peteris Krumins wrote:
> Hi,
>
> How often does IP Fragmentation occur?
> Is it safe to restrict any fragmented packets to 'come' into my
> network?
>
>
> P.Krumins
--
Daniel Fairchild - Chief Security Engineer | danielf@supportteam.net
^ permalink raw reply [flat|nested] 6+ messages in thread
* IP fragmentation
@ 2020-07-20 8:15 Alexander Petrovsky
2020-07-20 12:17 ` Edward Cree
0 siblings, 1 reply; 6+ messages in thread
From: Alexander Petrovsky @ 2020-07-20 8:15 UTC (permalink / raw)
To: xdp-newbies
Hello!
I have the eBPF/XDP based balancing router, it looks like facebook
katran, but a little bit smarter, we use random based balancing
algorithm, so also we have to learn how to sync connections between
nodes.
But, the main problem for us it's fragmented IP packets. Some times
ago I tried to use for such packets AF_XDP, fast pass them into the
user space, accumulate and after that pass back to the network, it was
a PoC. So, I wonder, is some chance that IP de-fragmentation functions
will be added into XDP?
Also, I have a strange idea, I could store such fragmented packets in
the LRU map, the original fragmented IP packet I could drop. When all
the fragments stored, I could make the decision about the destination
for balancing/routing. But now, here come problems, seems I could
construct a big packet / jumbo frame, but it seems a little bit ugly.
How could I emit all fragments from the map to the network after I've
got the last fragment?
--
Alexander Petrovsky
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: IP fragmentation
2020-07-20 8:15 IP fragmentation Alexander Petrovsky
@ 2020-07-20 12:17 ` Edward Cree
2020-07-20 14:47 ` Alexander Petrovsky
0 siblings, 1 reply; 6+ messages in thread
From: Edward Cree @ 2020-07-20 12:17 UTC (permalink / raw)
To: Alexander Petrovsky, xdp-newbies
On 20/07/2020 09:15, Alexander Petrovsky wrote:
> But, the main problem for us it's fragmented IP packets. Some times
> ago I tried to use for such packets AF_XDP, fast pass them into the
> user space, accumulate and after that pass back to the network, it was
> a PoC.
Not 100% sure this works because I haven't tried it, but as long as
packets aren't being re-ordered, you can do it without needing to
save the payload in a map.
All the map needs to store is (for each IPID being tracked) what host
this connection goes to.
If you receive a First Fragment (frag_off=0, MF=1), you look up the
tuple through the regular LB to pick a server, and record that host
in the map entry for the IPID.
For any other fragment, you look up the IPID in the map to get the
destination host, and if MF=0 you delete the map entry.
(If the IPID wasn't found, either drop or punt to userspace.)
Then TX/REDIRECT the packet to the appropriate host.
You might want to add some kind of simple ageing to this so that map
entries from interrupted/spurious fragment chains don't stick around
and build up over time.
The problem comes when 'middle' fragments can either come after the
last (MF=0) fragment (technically this can be handled by tracking
the byte range seen for the IPID, and not deleting from the map
until all bytes up to the frag_off+total_len of the last-frag have
been seen), or worse, before the first fragment. If the frag_off=0
fragment isn't the first one received, then this doesn't work
because you don't know at the time of receiving fragments what L4
ports they belong to. But I don't know how common that situation is
and whether having it take the slow-path is acceptable.
HTH,
-ed
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: IP fragmentation
2020-07-20 12:17 ` Edward Cree
@ 2020-07-20 14:47 ` Alexander Petrovsky
2020-07-21 12:33 ` Edward Cree
0 siblings, 1 reply; 6+ messages in thread
From: Alexander Petrovsky @ 2020-07-20 14:47 UTC (permalink / raw)
To: Edward Cree; +Cc: xdp-newbies
пн, 20 июл. 2020 г. в 15:17, Edward Cree <ecree@solarflare.com>:
>
> On 20/07/2020 09:15, Alexander Petrovsky wrote:
> > But, the main problem for us it's fragmented IP packets. Some times
> > ago I tried to use for such packets AF_XDP, fast pass them into the
> > user space, accumulate and after that pass back to the network, it was
> > a PoC.
> Not 100% sure this works because I haven't tried it, but as long as
> packets aren't being re-ordered, you can do it without needing to
> save the payload in a map.
> All the map needs to store is (for each IPID being tracked) what host
> this connection goes to.
> If you receive a First Fragment (frag_off=0, MF=1), you look up the
> tuple through the regular LB to pick a server, and record that host
> in the map entry for the IPID.
> For any other fragment, you look up the IPID in the map to get the
> destination host, and if MF=0 you delete the map entry.
> (If the IPID wasn't found, either drop or punt to userspace.)
> Then TX/REDIRECT the packet to the appropriate host.
> You might want to add some kind of simple ageing to this so that map
> entries from interrupted/spurious fragment chains don't stick around
> and build up over time.
>
> The problem comes when 'middle' fragments can either come after the
> last (MF=0) fragment (technically this can be handled by tracking
> the byte range seen for the IPID, and not deleting from the map
> until all bytes up to the frag_off+total_len of the last-frag have
> been seen), or worse, before the first fragment. If the frag_off=0
> fragment isn't the first one received, then this doesn't work
> because you don't know at the time of receiving fragments what L4
> ports they belong to. But I don't know how common that situation is
> and whether having it take the slow-path is acceptable.
>
> HTH,
> -ed
Unfortunately, for UDP I can't pick some _random_ host in case the
first _seen_ fragment it's not a First Fragment (frag_off=0, MF=1). In
this case, I have to accumulate ALL fragments in map. And on each
received fragment check, is all fragments are collected. I did it in
my PoC with AF_XDP, but in PoC all seems unreliable.
--
Alexander Petrovsky
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: IP fragmentation
2020-07-20 14:47 ` Alexander Petrovsky
@ 2020-07-21 12:33 ` Edward Cree
0 siblings, 0 replies; 6+ messages in thread
From: Edward Cree @ 2020-07-21 12:33 UTC (permalink / raw)
To: Alexander Petrovsky; +Cc: xdp-newbies
On 20/07/2020 15:47, Alexander Petrovsky wrote:
> Unfortunately, for UDP I can't pick some _random_ host in case the
> first _seen_ fragment it's not a First Fragment (frag_off=0, MF=1). In
> this case, I have to accumulate ALL fragments in map. And on each
> received fragment check, is all fragments are collected. I did it in
> my PoC with AF_XDP, but in PoC all seems unreliable.
That's why I say punt in that case (XDP_PASS and then have something
else downstream of it to handle the slowpath. However people did LB
before XDP came along. Idk, netfilter? Does that have hooks post-
reassembly?)
And probably when punting also record a map entry saying "we punted
this IPID" so that when the First Frag shows up, the slowpath gets
to see that one too and can do its reassembly.
So the map doesn't have to accumulate the fragments (the slowpath does
that), just their offsets and lengths so XDP can tell when all frags
have been passed to the slowpath and delete the map entry.
-ed
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2020-07-21 12:33 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2003-03-30 21:06 IP Fragmentation Peteris Krumins
2003-03-31 18:41 ` Daniel F. Chief Security Engineer -
-- strict thread matches above, loose matches on Subject: below --
2020-07-20 8:15 IP fragmentation Alexander Petrovsky
2020-07-20 12:17 ` Edward Cree
2020-07-20 14:47 ` Alexander Petrovsky
2020-07-21 12:33 ` Edward Cree
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.