X-Git-Url: https://git.ozlabs.org/?a=blobdiff_plain;f=pppd%2Foptions.c;h=fb83dee1f8b092623d7d862613c10b638a7d932b;hb=0b6b481854230b3ea1e613f05800f17eb4fcc204;hp=4870128868f63d10ecf1abc5b1562c06ca0f9416;hpb=36e867a96fbc20777c4d3cb15e7aa4f7180f1452;p=ppp.git diff --git a/pppd/options.c b/pppd/options.c index 4870128..fb83dee 100644 --- a/pppd/options.c +++ b/pppd/options.c @@ -40,7 +40,7 @@ * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ -#define RCSID "$Id: options.c,v 1.94 2004/11/04 09:46:50 paulus Exp $" +#define RCSID "$Id: options.c,v 1.97 2005/07/09 04:58:36 paulus Exp $" #include #include @@ -62,8 +62,8 @@ * libpcap-0.8.4. Until that is released, use DLT_PPP - but that means * we lose the inbound and outbound qualifiers. */ -#ifndef DLT_PPP_WITH_DIRECTION -#define DLT_PPP_WITH_DIRECTION DLT_PPP +#ifndef DLT_PPP_WITHDIRECTION +#define DLT_PPP_WITHDIRECTION DLT_PPP #endif #endif @@ -199,7 +199,8 @@ option_t general_options[] = { OPT_PRIOSUB | OPT_A2CLR | 1, &nodetach }, { "holdoff", o_int, &holdoff, - "Set time in seconds before retrying connection", OPT_PRIO }, + "Set time in seconds before retrying connection", + OPT_PRIO, &holdoff_specified }, { "idle", o_int, &idle_time_limit, "Set time in seconds before disconnecting idle link", OPT_PRIO }, @@ -272,7 +273,8 @@ option_t general_options[] = { "Stop after parsing, printing, and checking options", 1 }, { "child-timeout", o_int, &child_wait, - "Number of seconds to wait for child processes at exit" }, + "Number of seconds to wait for child processes at exit", + OPT_PRIO }, #ifdef HAVE_MULTILINK { "multilink", o_bool, &multilink, @@ -294,10 +296,10 @@ option_t general_options[] = { #endif #ifdef PPP_FILTER - { "pass-filter", 1, setpassfilter, + { "pass-filter", o_special, setpassfilter, "set filter for packets to pass", OPT_PRIO }, - { "active-filter", 1, setactivefilter, + { "active-filter", o_special, setactivefilter, "set filter for active pkts", OPT_PRIO }, #endif @@ -1445,13 +1447,13 @@ setpassfilter(argv) char **argv; { pcap_t *pc; - int ret = 0; + int ret = 1; - pc = pcap_open_dead(DLT_PPP_WITH_DIRECTION, 65535); + pc = pcap_open_dead(DLT_PPP_WITHDIRECTION, 65535); if (pcap_compile(pc, &pass_filter, *argv, 1, netmask) == -1) { option_error("error in pass-filter expression: %s\n", pcap_geterr(pc)); - ret = 1; + ret = 0; } pcap_close(pc); @@ -1466,13 +1468,13 @@ setactivefilter(argv) char **argv; { pcap_t *pc; - int ret = 0; + int ret = 1; - pc = pcap_open_dead(DLT_PPP_WITH_DIRECTION, 65535); + pc = pcap_open_dead(DLT_PPP_WITHDIRECTION, 65535); if (pcap_compile(pc, &active_filter, *argv, 1, netmask) == -1) { option_error("error in active-filter expression: %s\n", pcap_geterr(pc)); - ret = 1; + ret = 0; } pcap_close(pc);