5b063c8581
establish an L2TP VPN connection to its external IP address from the Windows XP box on your LAN, l2tpd(8) will reply (UDP) from its local IP address, and not external IP address. Implement the new global option "address" to aid in overcoming this problem. Also helps in environments with complex NAT configurations. Bump PORTREVISION. Approved by: sobomax
88 lines
2.7 KiB
C
88 lines
2.7 KiB
C
--- l2tpd.c.orig Mon Aug 19 17:12:17 2002
|
|
+++ l2tpd.c Wed Apr 16 16:07:19 2003
|
|
@@ -34,8 +34,6 @@
|
|
#include <netdb.h>
|
|
#include <string.h>
|
|
#include <fcntl.h>
|
|
-#include <netinet/in.h>
|
|
-#include <arpa/inet.h>
|
|
#ifdef USE_KERNEL
|
|
#include <sys/ioctl.h>
|
|
#endif
|
|
@@ -46,6 +44,7 @@
|
|
struct utsname uts;
|
|
int ppd = 1; /* Packet processing delay */
|
|
int control_fd; /* descriptor of control area */
|
|
+int control_fdw; /* descriptor of control area */
|
|
char *args;
|
|
|
|
char *dial_no_tmp; /* jz: Dialnumber for Outgoing Call */
|
|
@@ -384,6 +383,7 @@
|
|
|
|
/* close the control pipe fd */
|
|
close (control_fd);
|
|
+ close (control_fdw);
|
|
|
|
execv (PPPD, stropt);
|
|
log (LOG_WARN, "%s: Exec of %s failed!\n", __FUNCTION__, PPPD);
|
|
@@ -764,8 +764,8 @@
|
|
struct lac *lac;
|
|
int call;
|
|
int tunl;
|
|
- int cnt = -1;
|
|
- while (cnt)
|
|
+ int cnt = 1;
|
|
+ while (cnt > 0)
|
|
{
|
|
cnt = read (control_fd, buf, sizeof (buf));
|
|
if (cnt > 0)
|
|
@@ -920,7 +920,9 @@
|
|
}
|
|
/* Otherwise select goes nuts */
|
|
close (control_fd);
|
|
+ close (control_fdw);
|
|
control_fd = open (CONTROL_PIPE, O_RDONLY | O_NONBLOCK, 0600);
|
|
+ control_fdw = open (CONTROL_PIPE, O_WRONLY | O_NONBLOCK, 0600);
|
|
}
|
|
|
|
void usage(void) {
|
|
@@ -985,6 +987,7 @@
|
|
char buf[STRLEN];
|
|
int pidfilewritten=0;
|
|
|
|
+#ifndef __FreeBSD__
|
|
if((pid = fork()) < 0) {
|
|
log(LOG_LOG, "%s: Unable to fork ()\n",__FUNCTION__);
|
|
close(server_socket);
|
|
@@ -998,6 +1001,12 @@
|
|
to do a proper fix for this */
|
|
close(1);
|
|
close(2);
|
|
+#else
|
|
+ if (daemon(0, 0) != 0) {
|
|
+ log(LOG_LOG, "%s: daemon () failed\n", __FUNCTION__);
|
|
+ exit(1);
|
|
+ }
|
|
+#endif
|
|
|
|
/* Read previous pid file. */
|
|
if ((i = open(gconfig.pidfile,O_RDONLY)) > 0) {
|
|
@@ -1075,6 +1084,7 @@
|
|
init_scheduler ();
|
|
mkfifo (CONTROL_PIPE, 0600);
|
|
control_fd = open (CONTROL_PIPE, O_RDONLY | O_NONBLOCK, 0600);
|
|
+ control_fdw = open (CONTROL_PIPE, O_WRONLY | O_NONBLOCK, 0600);
|
|
if (control_fd < 0)
|
|
{
|
|
log (LOG_CRIT, "%s: Unable to open " CONTROL_PIPE " for reading.",
|
|
@@ -1087,8 +1097,8 @@
|
|
"Written by Mark Spencer, Copyright (C) 1998, Adtran, Inc.\n");
|
|
log (LOG_LOG, "Forked by Scott Balmos and David Stipp, (C) 2001\n");
|
|
log (LOG_LOG, "Inhereted by Jeff McAdams, (C) 2002\n");
|
|
- log (LOG_LOG, "%s version %s on a %s, port %d\n", uts.sysname,
|
|
- uts.release, uts.machine, gconfig.port);
|
|
+ log (LOG_LOG, "%s version %s on a %s, addr %s, port %d\n", uts.sysname,
|
|
+ uts.release, uts.machine, inet_ntoa(gconfig.addr), gconfig.port);
|
|
lac = laclist;
|
|
while (lac)
|
|
{
|