X-Git-Url: https://git.ozlabs.org/?a=blobdiff_plain;f=pppd%2Fplugins%2Frp-pppoe%2Fplugin.c;h=cd93bfa1887dcd30bf6bcb508305dc3bae5e78ca;hb=6e6bb3246106e680463c106d1ee6b773fc4f9c5a;hp=0ef43446c280f1e7c24115b312ae6ac45ba20ee1;hpb=e5b7cafa28aeba66499fa26b286192529e5fde15;p=ppp.git diff --git a/pppd/plugins/rp-pppoe/plugin.c b/pppd/plugins/rp-pppoe/plugin.c index 0ef4344..cd93bfa 100644 --- a/pppd/plugins/rp-pppoe/plugin.c +++ b/pppd/plugins/rp-pppoe/plugin.c @@ -22,7 +22,7 @@ ***********************************************************************/ static char const RCSID[] = -"$Id: plugin.c,v 1.9 2003/04/07 00:01:46 paulus Exp $"; +"$Id: plugin.c,v 1.12 2004/11/04 10:07:37 paulus Exp $"; #define _GNU_SOURCE 1 #include "pppoe.h" @@ -80,7 +80,7 @@ static option_t Options[] = { "Be verbose about discovered access concentrators"}, { NULL } }; -int (*OldDevnameHook)(char *cmd, char **argv, int doit) = NULL; + static PPPoEConnection *conn = NULL; /********************************************************************** @@ -144,7 +144,8 @@ PPPOEConnectDevice(void) } else { discovery(conn); if (conn->discoveryState != STATE_SESSION) { - fatal("Unable to complete PPPoE Discovery"); + error("Unable to complete PPPoE Discovery"); + return -1; } } @@ -243,6 +244,8 @@ PPPOEDisconnectDevice(void) return; } close(conn->sessionSocket); + /* don't send PADT?? */ + close(conn->discoverySocket); } static void @@ -276,14 +279,15 @@ PPPoEDevnameHook(char *cmd, char **argv, int doit) int fd; struct ifreq ifr; - /* Only do it if name is "ethXXX" or "nic-XXXX. In latter case, - strip off the "nic-" */ + /* Only do it if name is "ethXXX", "nasXXX", "tapXXX" or "nic-XXXX. + In latter case strip off the "nic-" */ /* Thanks to Russ Couturier for this fix */ if (strlen(cmd) > 4 && !strncmp(cmd, "nic-", 4)) { /* Strip off "nic-" */ cmd += 4; - } else if (strlen(cmd) < 4 || strncmp(cmd, "eth", 3)) { - if (OldDevnameHook) return OldDevnameHook(cmd, argv, doit); + } else if (strlen(cmd) < 4 + || (strncmp(cmd, "eth", 3) && strncmp(cmd, "nas", 3) + && strncmp(cmd, "tap", 3) && strncmp(cmd, "br", 2))) { return 0; } @@ -341,7 +345,6 @@ PPPoEDevnameHook(char *cmd, char **argv, int doit) return 1; } - if (OldDevnameHook) r = OldDevnameHook(cmd, argv, doit); return r; }