Opened 19 years ago
Closed 8 years ago
#812 closed enhancement (fixed)
Port PPP to the new stack
Reported by: | axeld | Owned by: | nobody |
---|---|---|---|
Priority: | normal | Milestone: | Unscheduled |
Component: | Network & Internet/PPP | Version: | |
Keywords: | Cc: | wkornewald, linlongzhou@… | |
Blocked By: | Blocking: | ||
Platform: | All |
Description
Port over Waldemar's PPP code to the new networking stack.
Attachments (6)
Change History (29)
comment:1 by , 18 years ago
Cc: | added |
---|
comment:2 by , 17 years ago
Milestone: | R1 Network Stack → R1 |
---|---|
Platform: | → All |
comment:3 by , 12 years ago
patch: | 0 → 1 |
---|
follow-up: 6 comment:4 by , 12 years ago
Usage: 1, merge the patch and compile 2, put ppp1 template configuration file to /boot/home/config/settings/kernel/drivers/ptpnet/ppp1 and change the settings. 3, In terminal type: ifconfig ppp1 up
What is done: 1, port mbuf to net_buffer 2, basic pppoe support
Todo: 1, KPPPManager optimization, now only support basic function 2, autoconnect 3, DNS server update to resolv.conf
done in latest patch
4, spelling, code style, debug information cleanup.
Problem: 1, All lock should be recheckd! 2, Files 'haiku/src/add-ons/kernel/network/ppp/ipcp/{port_before.h, port_after.h, bittypes.h, config.h} are copied from haiku/src/kits/network/libbind/ dir. There should be better solution.
The 2nd one is solved by using simplified inet_addr.c located src/system/kernel/util/. It has no header dependency as the old one located in libbind.
comment:5 by , 12 years ago
Cc: | added |
---|
follow-up: 7 comment:6 by , 12 years ago
Replying to mshlyn:
Usage: 1, merge the patch and compile 2, put ppp1 template configuration file to /boot/home/config/settings/kernel/drivers/ptpnet/ppp1 and change the settings. 3, In terminal type: ifconfig ppp1 up
I think it is a good idea to ask for testing help in the haiku-development mailing list too. BTW, are you using any Source Code Management systems for your work? Lot of Haiku development branches, hosted on github, for example, send commit notifications into haiku-development mail list. IMO, it is a good way to stay in the light and receive immediate advices from our developers. ;-)
And thank you very much for this work! It was surprising delight seeing it.
follow-up: 8 comment:7 by , 12 years ago
Replying to siarzhuk:
Replying to mshlyn:
Usage: 1, merge the patch and compile 2, put ppp1 template configuration file to /boot/home/config/settings/kernel/drivers/ptpnet/ppp1 and change the settings. 3, In terminal type: ifconfig ppp1 up
I think it is a good idea to ask for testing help in the haiku-development mailing list too. BTW, are you using any Source Code Management systems for your work? Lot of Haiku development branches, hosted on github, for example, send commit notifications into haiku-development mail list. IMO, it is a good way to stay in the light and receive immediate advices from our developers. ;-)
This is the first time I submit patch. There is much for me to learn. I use git on my local PC. Due to bad plan,there were lots experimental code in my git repo. That is why I only submitted pure diff here. I can upload the format-patch if it helps. As for haiku branch, I only know the official one. Do you have any suggest? I would like to receive immediate advice from the developers.
And thank you very much for this work! It was surprising delight seeing it.
My pleasure if it helps a bit. And thanks very much for you good advice!
comment:8 by , 12 years ago
Replying to mshlyn:
As for haiku branch, I only know the official one. Do you have any suggest? I would like to receive immediate advice from the developers.
If you asking about forked branches of Haiku - there are no such ones at the moment, AFAIK. Most of known repositories are just development branches - like your one. And all mentioned "experiments" are normal development workflow, in my opinion. ;-)
BTW, Trac is targeted mainly for problem discussions so you are welcome to http://www.freelists.org/list/haiku-development :-)
comment:9 by , 12 years ago
Would it be worthwhile for mshlyn to rewrite his git history, so as to remove/consolidate the experimental changes? The archive attachment contains 37 patches. :-D
comment:10 by , 12 years ago
Sorry for the long delay, mshlyn! Your work is much appreciated, and also thanks for providing it in git format-patch format!
Your patch has a few issues so that I would not like to submit it as is:
- Why do you copy files like asm_defs.h, net_stack_driver.h, and directories.h? If you need them, they are already in the tree. You may need to alter the Jamfile to make visible. For example, to add private kernel headers, you can use something like
UsePrivateKernelHeaders
. - Your patch could use some general cleanup: things like commenting out includes, etc., debug output like the changes to , or the changes made to build/jam/ReleaseBuildProfiles, src/add-ons/kernel/network/datalink_protocols/ethernet_frame/ethernet_frame.cpp, and src/add-ons/kernel/network/devices/ethernet/ethernet.cpp should not be part of it.
- Why is KPPPManager.cpp in its own directory? Besides that, we always use lower case for directory names (there are a few exceptions, but those should be fixed instead of introducing new ones).
- A bit more documentation would be great. For example, what is Interface::ChangeAddress() doing exactly, and why is it needed? I mean, why don't you just set the address like ifconfig would do?
- What does "src for Y470" mean, and why is it just empty?
- The get_interface_address_by_name you introduce deviates from the usual argument ordering (domain comes first).
- Why do you need those functions, anyway?
And also, there is a ton of coding style issues - I mention a few of those that I came across:
- There is a space between 'if', 'while', 'switch', etc. and '('
- Names like 'nd' should be avoided -- use domain instead.
- Space before and after operators (ie.
name == NULL
instead ofname==NULL
). - We use camel case for variables, ie. pppInterfaceAddress instead of ppp_interface_address.
- Two lines between functions.
- Includes are grouped by origin, the groups are ordered most generic to most specific, and the includes within the groups are ordered alphabetically.
- The '{' goes to the end of the line, and is preceded by a space (like src/add-ons/kernel/network/ppp/shared/libkernelppp/settings_tools.cpp).
- If you always exit an 'if' block with 'return', don't use 'else' when it's not needed.
- Space after ''
- Space after ','
- Don't use superfluous parenthesis as in pppoe_input().
I hope you are willing to continue working on this?
comment:11 by , 12 years ago
Fixed lots of issues pointed out by axeld, including style issues. What is left:
1, Integrate PPPManager into libkernelppp 2, pppconfig, ppp_up are still not working
by , 11 years ago
Attachment: | patches_2014_01_04.tar.bz2 added |
---|
'git pull --rebase' to the latest master
by , 11 years ago
Attachment: | 0001-Add-pppoe-to-haiku-image-and-minor-compilation-fixes.patch added |
---|
Replaces patch 0042 of the patchset
comment:16 by , 11 years ago
It at least compiles again. Am not sure if the use of volatile integers should be replaced with just int32 or not. The use of atomic_add family of functions require casting to int32* to compile. Probably better to switch to int32 and use atomic getters instead?
comment:17 by , 11 years ago
Volatile integers are not needed here. Unfortunately, this patch series in current form is very difficult to review as the majority of the patches are fixes to the previous ones and definitely should not be merged. However, I have noticed that IPCP::fID
is accessed both using normal and atomic operations and that doesn't look good. Actually, I am not even sure that increment of fID
really needs to be atomic (but I may be wrong).
comment:18 by , 11 years ago
Owner: | set to |
---|---|
Status: | new → assigned |
Hmm, so if I understand correctly:
- all teh patchez should be combined into logical chunks
- Volaitle ints should be removed
- Atomic-only operations should be used on IPCP::fID
...and it should be tested on an actual dialup line. Right?
comment:19 by , 10 years ago
Milestone: | R1 → Unscheduled |
---|
Moving PPP related tickets out of R1 milestone (Prop #2).
comment:20 by , 9 years ago
The patchset now lives at https://github.com/waddlesplash/haiku/tree/pppp; I've rebased it against master and will work on it as time allows.
comment:23 by , 8 years ago
Resolution: | → fixed |
---|---|
Status: | assigned → closed |
Since this was all merged i'm going to close this one. Any additional issues should be tracked in new tickets.
I should at least watch this task...