xref: /dflybsd-src/usr.sbin/ppp/tun.c (revision 86d7f5d305c6adaa56ff4582ece9859d73106103)
1*86d7f5d3SJohn Marino /*-
2*86d7f5d3SJohn Marino  * Copyright (c) 1997 Brian Somers <brian@Awfulhak.org>
3*86d7f5d3SJohn Marino  * All rights reserved.
4*86d7f5d3SJohn Marino  *
5*86d7f5d3SJohn Marino  * Redistribution and use in source and binary forms, with or without
6*86d7f5d3SJohn Marino  * modification, are permitted provided that the following conditions
7*86d7f5d3SJohn Marino  * are met:
8*86d7f5d3SJohn Marino  * 1. Redistributions of source code must retain the above copyright
9*86d7f5d3SJohn Marino  *    notice, this list of conditions and the following disclaimer.
10*86d7f5d3SJohn Marino  * 2. Redistributions in binary form must reproduce the above copyright
11*86d7f5d3SJohn Marino  *    notice, this list of conditions and the following disclaimer in the
12*86d7f5d3SJohn Marino  *    documentation and/or other materials provided with the distribution.
13*86d7f5d3SJohn Marino  *
14*86d7f5d3SJohn Marino  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15*86d7f5d3SJohn Marino  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16*86d7f5d3SJohn Marino  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17*86d7f5d3SJohn Marino  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18*86d7f5d3SJohn Marino  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19*86d7f5d3SJohn Marino  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20*86d7f5d3SJohn Marino  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21*86d7f5d3SJohn Marino  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22*86d7f5d3SJohn Marino  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23*86d7f5d3SJohn Marino  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24*86d7f5d3SJohn Marino  * SUCH DAMAGE.
25*86d7f5d3SJohn Marino  *
26*86d7f5d3SJohn Marino  * $FreeBSD: src/usr.sbin/ppp/tun.c,v 1.20.2.4 2002/09/01 02:12:32 brian Exp $
27*86d7f5d3SJohn Marino  * $DragonFly: src/usr.sbin/ppp/tun.c,v 1.4 2004/02/03 07:11:47 dillon Exp $
28*86d7f5d3SJohn Marino  */
29*86d7f5d3SJohn Marino 
30*86d7f5d3SJohn Marino #include <sys/param.h>
31*86d7f5d3SJohn Marino 
32*86d7f5d3SJohn Marino #include <sys/socket.h>		/* For IFF_ defines */
33*86d7f5d3SJohn Marino #ifndef __DragonFly__
34*86d7f5d3SJohn Marino #include <net/if.h>		/* For IFF_ defines */
35*86d7f5d3SJohn Marino #endif
36*86d7f5d3SJohn Marino #include <net/route.h>
37*86d7f5d3SJohn Marino #include <netinet/in.h>
38*86d7f5d3SJohn Marino #include <net/if_types.h>
39*86d7f5d3SJohn Marino #include <net/tun/if_tun.h>
40*86d7f5d3SJohn Marino #include <netinet/in_systm.h>
41*86d7f5d3SJohn Marino #include <netinet/ip.h>
42*86d7f5d3SJohn Marino #include <sys/un.h>
43*86d7f5d3SJohn Marino 
44*86d7f5d3SJohn Marino #include <errno.h>
45*86d7f5d3SJohn Marino #include <string.h>
46*86d7f5d3SJohn Marino #if defined(__OpenBSD__) || defined(__NetBSD__)
47*86d7f5d3SJohn Marino #include <sys/ioctl.h>
48*86d7f5d3SJohn Marino #endif
49*86d7f5d3SJohn Marino #include <stdio.h>
50*86d7f5d3SJohn Marino #include <termios.h>
51*86d7f5d3SJohn Marino #ifdef __NetBSD__
52*86d7f5d3SJohn Marino #include <unistd.h>
53*86d7f5d3SJohn Marino #endif
54*86d7f5d3SJohn Marino 
55*86d7f5d3SJohn Marino #include "layer.h"
56*86d7f5d3SJohn Marino #include "mbuf.h"
57*86d7f5d3SJohn Marino #include "log.h"
58*86d7f5d3SJohn Marino #include "id.h"
59*86d7f5d3SJohn Marino #include "timer.h"
60*86d7f5d3SJohn Marino #include "lqr.h"
61*86d7f5d3SJohn Marino #include "hdlc.h"
62*86d7f5d3SJohn Marino #include "defs.h"
63*86d7f5d3SJohn Marino #include "fsm.h"
64*86d7f5d3SJohn Marino #include "throughput.h"
65*86d7f5d3SJohn Marino #include "iplist.h"
66*86d7f5d3SJohn Marino #include "slcompress.h"
67*86d7f5d3SJohn Marino #include "ncpaddr.h"
68*86d7f5d3SJohn Marino #include "ipcp.h"
69*86d7f5d3SJohn Marino #include "filter.h"
70*86d7f5d3SJohn Marino #include "descriptor.h"
71*86d7f5d3SJohn Marino #include "lcp.h"
72*86d7f5d3SJohn Marino #include "ccp.h"
73*86d7f5d3SJohn Marino #include "link.h"
74*86d7f5d3SJohn Marino #include "mp.h"
75*86d7f5d3SJohn Marino #include "iface.h"
76*86d7f5d3SJohn Marino #ifndef NORADIUS
77*86d7f5d3SJohn Marino #include "radius.h"
78*86d7f5d3SJohn Marino #endif
79*86d7f5d3SJohn Marino #include "ipv6cp.h"
80*86d7f5d3SJohn Marino #include "ncp.h"
81*86d7f5d3SJohn Marino #include "bundle.h"
82*86d7f5d3SJohn Marino #include "tun.h"
83*86d7f5d3SJohn Marino 
84*86d7f5d3SJohn Marino void
tun_configure(struct bundle * bundle)85*86d7f5d3SJohn Marino tun_configure(struct bundle *bundle)
86*86d7f5d3SJohn Marino {
87*86d7f5d3SJohn Marino #ifdef __NetBSD__
88*86d7f5d3SJohn Marino   struct ifreq ifr;
89*86d7f5d3SJohn Marino   int s;
90*86d7f5d3SJohn Marino 
91*86d7f5d3SJohn Marino   s = socket(PF_INET, SOCK_DGRAM, 0);
92*86d7f5d3SJohn Marino 
93*86d7f5d3SJohn Marino   if (s < 0) {
94*86d7f5d3SJohn Marino     log_Printf(LogERROR, "tun_configure: socket(): %s\n", strerror(errno));
95*86d7f5d3SJohn Marino     return;
96*86d7f5d3SJohn Marino   }
97*86d7f5d3SJohn Marino 
98*86d7f5d3SJohn Marino   sprintf(ifr.ifr_name, "tun%d", bundle->unit);
99*86d7f5d3SJohn Marino   ifr.ifr_mtu = bundle->iface->mtu;
100*86d7f5d3SJohn Marino   if (ioctl(s, SIOCSIFMTU, &ifr) < 0)
101*86d7f5d3SJohn Marino       log_Printf(LogERROR, "tun_configure: ioctl(SIOCSIFMTU): %s\n",
102*86d7f5d3SJohn Marino              strerror(errno));
103*86d7f5d3SJohn Marino 
104*86d7f5d3SJohn Marino   close(s);
105*86d7f5d3SJohn Marino #else
106*86d7f5d3SJohn Marino   struct tuninfo info;
107*86d7f5d3SJohn Marino 
108*86d7f5d3SJohn Marino   memset(&info, '\0', sizeof info);
109*86d7f5d3SJohn Marino   info.type = IFT_PPP;
110*86d7f5d3SJohn Marino   info.mtu = bundle->iface->mtu;
111*86d7f5d3SJohn Marino 
112*86d7f5d3SJohn Marino   info.baudrate = bundle->bandwidth;
113*86d7f5d3SJohn Marino #ifdef __OpenBSD__
114*86d7f5d3SJohn Marino   info.flags = IFF_UP|IFF_POINTOPOINT|IFF_MULTICAST;
115*86d7f5d3SJohn Marino #endif
116*86d7f5d3SJohn Marino   if (ID0ioctl(bundle->dev.fd, TUNSIFINFO, &info) < 0)
117*86d7f5d3SJohn Marino     log_Printf(LogERROR, "tun_configure: ioctl(TUNSIFINFO): %s\n",
118*86d7f5d3SJohn Marino 	      strerror(errno));
119*86d7f5d3SJohn Marino #endif
120*86d7f5d3SJohn Marino }
121