[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <52CB34F9.6020906@aimvalley.nl>
Date: Mon, 06 Jan 2014 23:58:01 +0100
From: Norbert van Bolhuis <nvbolhuis@...valley.nl>
To: netdev@...r.kernel.org
CC: Daniel Borkmann <dborkman@...hat.com>,
David Miller <davem@...emloft.net>, uaca@...mni.uv.es
Subject: single process receives own frames due to PACKET_MMAP
Our application uses raw AF_PACKET socket to send and receive
on one particular ethernet interface.
Recently we started using PACKET_MMAP (TPACKET_V2). This makes
the Appl use a TX socket and a RX socket.
Both sockets are bound to the same (eth) interface. I noticed
the RX socket receives all frames that are sent via the
TX socket (same process, different thread). This I do not want.
I know it is supposed to happen for different processes
(otherwise wireshark won't work), but I did not expect it to
happen for one single process (with different threads).
I can filter them out in user-space (PACKET_OUTGOING)
or via kernel packet filter (SO_ATTACH_FILTER), but performance is
critical.
I wonder whether this (PACKET_MMAP) behaviour is OK.
It did not happen before (with a non-PACKET_MMAP AF_PACKET socket
which was used by both threads of the same Appl process). So
why is it happening now ?
I'd say it makes no sense to make the same process receive its
own transmitted frames on that same interface (unless its lo).
If I'm not doing something wrong, this means this behaviour
causes my CPU to be loaded much more (since all transmitted frames
have to be filtered out).
Let me know what you think.
thanks,
Norbert van Bolhuis
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists