/* tunctl.c - Control tap/tun network devices. * * Copyright 2016 Rob Landley <rob@landley.net> * * See http://kernel.org/doc/Documentation/networking/tuntap.txt * * This is useful for things like "kvm -netdev tap" and containers. * See https://landley.net/lxc/02-networking.html for example usage. * * todo: bridge mode * -b bridge daemon (forwards packets between NAME and NAME2 interfaces) USE_TUNCTL(NEWTOY(tunctl, "<1>1t|d|u:T[!td]", TOYFLAG_USR|TOYFLAG_BIN)) config TUNCTL bool "tunctl" default y help usage: tunctl [-dtT] [-u USER] NAME Create and delete tun/tap virtual ethernet devices. -T Use tap (ethernet frames) instead of tun (ip packets) -d Delete tun/tap device -t Create tun/tap device -u Set owner (user who can read/write device without root access) */ #define FOR_tunctl #include "toys.h" #include <linux/if_tun.h> GLOBALS( char *user; ) void tunctl_main(void) { struct ifreq *ifr = (void *)toybuf; uid_t u = TT.user ? xgetuid(TT.user) : 0; int fd = xopen("/dev/net/tun", O_RDWR); // Associate filehandle with device ifr->ifr_flags = ((toys.optflags&FLAG_T) ? IFF_TUN : IFF_TAP)|IFF_NO_PI; strncpy(ifr->ifr_name, *toys.optargs, sizeof(ifr->ifr_name)); xioctl(fd, TUNSETIFF, toybuf); if (toys.optflags&FLAG_t) { xioctl(fd, TUNSETPERSIST, (void *)1); xioctl(fd, TUNSETOWNER, (void *)(long)u); } else xioctl(fd, TUNSETPERSIST, (void *)0); }