xref: /aosp_15_r20/external/toybox/toys/net/tunctl.c (revision cf5a6c84e2b8763fc1a7db14496fd4742913b199)
1*cf5a6c84SAndroid Build Coastguard Worker /* tunctl.c - Control tap/tun network devices.
2*cf5a6c84SAndroid Build Coastguard Worker  *
3*cf5a6c84SAndroid Build Coastguard Worker  * Copyright 2016 Rob Landley <[email protected]>
4*cf5a6c84SAndroid Build Coastguard Worker  *
5*cf5a6c84SAndroid Build Coastguard Worker  * See http://kernel.org/doc/Documentation/networking/tuntap.txt
6*cf5a6c84SAndroid Build Coastguard Worker  *
7*cf5a6c84SAndroid Build Coastguard Worker  * This is useful for things like "kvm -netdev tap" and containers.
8*cf5a6c84SAndroid Build Coastguard Worker  * See https://landley.net/lxc/02-networking.html for example usage.
9*cf5a6c84SAndroid Build Coastguard Worker  *
10*cf5a6c84SAndroid Build Coastguard Worker  * TODO: bridge mode
11*cf5a6c84SAndroid Build Coastguard Worker  *  -b	bridge daemon (forwards packets between NAME and NAME2 interfaces)
12*cf5a6c84SAndroid Build Coastguard Worker 
13*cf5a6c84SAndroid Build Coastguard Worker 
14*cf5a6c84SAndroid Build Coastguard Worker USE_TUNCTL(NEWTOY(tunctl, "<1>1t|d|u:T[!td]", TOYFLAG_USR|TOYFLAG_BIN))
15*cf5a6c84SAndroid Build Coastguard Worker 
16*cf5a6c84SAndroid Build Coastguard Worker config TUNCTL
17*cf5a6c84SAndroid Build Coastguard Worker   bool "tunctl"
18*cf5a6c84SAndroid Build Coastguard Worker   default y
19*cf5a6c84SAndroid Build Coastguard Worker   help
20*cf5a6c84SAndroid Build Coastguard Worker     usage: tunctl [-dtT] [-u USER] NAME
21*cf5a6c84SAndroid Build Coastguard Worker 
22*cf5a6c84SAndroid Build Coastguard Worker     Create and delete tun/tap virtual ethernet devices.
23*cf5a6c84SAndroid Build Coastguard Worker 
24*cf5a6c84SAndroid Build Coastguard Worker     -T	Use tap (ethernet frames) instead of tun (ip packets)
25*cf5a6c84SAndroid Build Coastguard Worker     -d	Delete tun/tap device
26*cf5a6c84SAndroid Build Coastguard Worker     -t	Create tun/tap device
27*cf5a6c84SAndroid Build Coastguard Worker     -u	Set owner (user who can read/write device without root access)
28*cf5a6c84SAndroid Build Coastguard Worker */
29*cf5a6c84SAndroid Build Coastguard Worker 
30*cf5a6c84SAndroid Build Coastguard Worker #define FOR_tunctl
31*cf5a6c84SAndroid Build Coastguard Worker #include "toys.h"
32*cf5a6c84SAndroid Build Coastguard Worker #include <linux/if_tun.h>
33*cf5a6c84SAndroid Build Coastguard Worker 
GLOBALS(char * u;)34*cf5a6c84SAndroid Build Coastguard Worker GLOBALS(
35*cf5a6c84SAndroid Build Coastguard Worker   char *u;
36*cf5a6c84SAndroid Build Coastguard Worker )
37*cf5a6c84SAndroid Build Coastguard Worker 
38*cf5a6c84SAndroid Build Coastguard Worker void tunctl_main(void)
39*cf5a6c84SAndroid Build Coastguard Worker {
40*cf5a6c84SAndroid Build Coastguard Worker   struct ifreq *ifr = (void *)toybuf;
41*cf5a6c84SAndroid Build Coastguard Worker   uid_t u = TT.u ?  xgetuid(TT.u) : 0;
42*cf5a6c84SAndroid Build Coastguard Worker   int fd = xopen("/dev/net/tun", O_RDWR);
43*cf5a6c84SAndroid Build Coastguard Worker 
44*cf5a6c84SAndroid Build Coastguard Worker   // Associate filehandle with device
45*cf5a6c84SAndroid Build Coastguard Worker   ifr->ifr_flags = (FLAG(T) ? IFF_TUN : IFF_TAP)|IFF_NO_PI;
46*cf5a6c84SAndroid Build Coastguard Worker   strncpy(ifr->ifr_name, *toys.optargs, sizeof(ifr->ifr_name));
47*cf5a6c84SAndroid Build Coastguard Worker   xioctl(fd, TUNSETIFF, toybuf);
48*cf5a6c84SAndroid Build Coastguard Worker 
49*cf5a6c84SAndroid Build Coastguard Worker   if (FLAG(t)) {
50*cf5a6c84SAndroid Build Coastguard Worker     xioctl(fd, TUNSETPERSIST, (void *)1);
51*cf5a6c84SAndroid Build Coastguard Worker     xioctl(fd, TUNSETOWNER, (void *)(long)u);
52*cf5a6c84SAndroid Build Coastguard Worker   } else xioctl(fd, TUNSETPERSIST, (void *)0);
53*cf5a6c84SAndroid Build Coastguard Worker }
54