From: James Chapman <jchapman@katalix.com>
To: Patrick McHardy <kaber@trash.net>
Cc: netdev@vger.kernel.org
Subject: Re: [PATCH 1/5 2.6.21-rc4] l2tp: pppol2tp core
Date: Sat, 24 Mar 2007 19:01:35 +0000 [thread overview]
Message-ID: <4605758F.90205@katalix.com> (raw)
In-Reply-To: <46052FC0.8080804@trash.net>
Patrick McHardy wrote:
> James Chapman wrote:
>> [PPPOL2TP]: Add PPP-over-L2TP driver core.
>>
>> This driver handles only L2TP data frames; control frames are handled
>> by a userspace application. The dfriver implements L2TP using the
>> PPPoX socket family. Data is sent or received using regular socket
>> sendmsg() / recvmsg() calls. Kernel parameters of the socket can be
>> read or modified using ioctl() or [gs]etsockopt() calls.
>
>
> The interaction with UDP sockets looks pretty horrible IMO. On the
> send side I don't see why you can't simply build the UDP header
> yourself instead of doing these set_fs + sendmsgs hacks.
Wouldn't that effectively duplicate the code in udp_sendmsg()? If I
don't use a socket, I'd also have to build an IP header and feed the
frame into the IP stack for outbound routing. It doesn't feel like the
right thing to do.
One reason for using the L2TP tunnel's UDP socket directly was to have
the data traffic carried by all sessions in that tunnel use the tunnel's
socket buffer, thereby ensuring that one tunnel's data can't starve
another tunnel.
> On the
> receive side I it would be nice if you could use the encapsulation
> socket stuff thats also used by IPsec.
Can you point me at some example code, please?
> A couple of random comments:
>
> - your list locking is broken
Stupid me. Thanks.
> - list_for_each_entry_safe is only needed if you remove something
> while iterating, its no replacement for locking
I've gotten into a bad habit of always using list_for_each_entry_safe.
I'll fix these (with locking).
> - SOCK_2_SESSION/SOCK_2_TUNNEL are terribly ugly and should
> probably be inline functions that use BUG_ON in case of an
> invalid magic
ok
> - You should use skb_queue_walk for queue walking
ok
> - You should use endian-annotated types
I hadn't noticed them before. Will do.
> - pppol2tp_fget: why do you want to open sockets for other processes?
> I hope this can go together with the sendmsg hacks
There are two userspace daemons: l2tpd and pppd. L2ptd opens a UDP
tunnel socket and sets up one or more L2TP sessions in that tunnel. When
a new session is established, l2tpd spawns a pppd process (per session).
The pppd process creates a PPPoL2TP socket (this driver). The PPPoL2TP
socket is associated with the tunnel UDP socket that was created by
l2tpd. So on creating a new PPPoX socket, the connect() handling needs
to find the UDP socket of the tunnel. Since connect() runs in the
context of pppd, it needs a way of doing a sock lookup to find the UDP
socket that was created by l2tpd.
Thanks for the comments. Please get back to me about the socket usage
questions. Meanwhile I'll work on fixing the other things you noted.
--
James Chapman
Katalix Systems Ltd
http://www.katalix.com
Catalysts for your Embedded Linux software development
next prev parent reply other threads:[~2007-03-24 19:01 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-03-23 23:07 [PATCH 1/5 2.6.21-rc4] l2tp: pppol2tp core James Chapman
2007-03-24 0:22 ` Florian Zumbiehl
2007-03-24 17:37 ` James Chapman
2007-03-24 18:07 ` Florian Zumbiehl
2007-03-24 14:03 ` Patrick McHardy
2007-03-24 19:01 ` James Chapman [this message]
2007-03-24 19:26 ` David Miller
2007-03-24 20:56 ` Patrick McHardy
2007-03-25 16:00 ` James Chapman
2007-03-27 14:37 ` Patrick McHardy
2007-03-24 21:58 ` Patrick McHardy
2007-03-25 16:12 ` James Chapman
2007-03-27 11:32 ` Ingo Oeser
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4605758F.90205@katalix.com \
--to=jchapman@katalix.com \
--cc=kaber@trash.net \
--cc=netdev@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).