Files
poky/scripts/poky-qemu-ifup
Jeff Dike 6ea1ed5f7b poky-qemu-[ifup|ifdown]: Use native tunctl
poky-qemu-ifup can run standalone by root in order to configure a bank
of tap devices for later qemu use.

These devices will, if possible, be owned by a specified group to
which qemu users must belong.

If the kernel is too old to support TUNSETGROUP, then it falls back to
setting the tap device to be owned by a particular user, and that user
will be the only one allowed to use it.

Also overall usability improvements to the scripts, usage() help, etc.

Signed-off-by: Jeff Dike <jdike@linux.intel.com>
Signed-off-by: Scott Garman <scott.a.garman@intel.com>
2010-08-20 16:20:10 +01:00

3.3 KiB
Executable File

#!/bin/bash

QEMU network interface configuration script. This utility needs to

be run as root, and will use the tunctl binary from a Poky sysroot.

Note: many Linux distros these days still use an older version of

tunctl which does not support the group permissions option, hence

the need to use Poky's version.

If this script is being run standalone in order to set up a bank of tap

devices for later qemu use, then a group id must be the first argument.

The resulting tap device will be group-owned by this group, and qemu

users must be members of this group.

If the kernel is too old to support TUNSETGROUP, then a user must be passed

in as the second argument, the tap device will be owned by that user, and

only that user will be able to use it.

Copyright (c) 2006-2010 Intel Corp.

This program is free software; you can redistribute it and/or modify

it under the terms of the GNU General Public License version 2 as

published by the Free Software Foundation.

This program is distributed in the hope that it will be useful,

but WITHOUT ANY WARRANTY; without even the implied warranty of

MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the

GNU General Public License for more details.

You should have received a copy of the GNU General Public License along

with this program; if not, write to the Free Software Foundation, Inc.,

51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.

usage() { echo "$0 {uid} " echo "Where uid is only included if this script complains when it's missing" }

if $# -lt 2 ; then usage exit 1 fi

USER="" GROUP="-g $1" if [ $# -eq 2 ]; then NATIVE_SYSROOT_DIR=$2 else USER=$2 NATIVE_SYSROOT_DIR=$3 fi

TUNCTL=$NATIVE_SYSROOT_DIR/usr/bin/tunctl if [ ! -e "$TUNCTL" ]; then echo "Error: Unable to find tunctl binary in '$NATIVE_SYSROOT_DIR/usr/bin'"

if [[ "$NATIVE_SYSROOT_DIR" =~ ^\/opt\/poky ]]; then
	echo "This shouldn't happen - something is wrong with your toolchain installation"
else
	echo "Have you run 'bitbake qemu-helper-native'?"
fi

exit 1

fi

TAP=$TUNCTL -b $GROUP 2>&1 STATUS=$? if ; then # TUNSETGROUP failed because of permissions or the kernel being too old # Retry, falling back to a specific user if [ "$USER" = "" ]; then echo "TUNSETGROUP failed - add a username to the command line in order" echo "to have the tap device owned by that user" exit 1 fi TAP=$TUNCTL -b -u $USER 2>&1 STATUS=$? # Force this to appear on stderr in order that the user sees it if this # is running from poky-qemu-internal and in order to avoid having this # output confuse it. echo "Only user $USER will be able to use $TAP - upgrade the kernel to " 1>&2 echo "2.6.23 or later in order to allow group access to tap devices" 1>&2 fi if [ $STATUS -ne 0 ]; then echo "tunctl failed:" echo $TAP exit 1 fi

IFCONFIG=which ifconfig if [ "x$IFCONFIG" = "x" ]; then # better than nothing... IFCONFIG=/sbin/ifconfig fi

n=$[ echo $TAP | sed 's/tap//' + 1 ] $IFCONFIG $TAP 192.168.7.$n

setup NAT for tap0 interface to have internet access in QEMU

IPTABLES=which iptables if [ "x$IPTABLES" = "x" ]; then IPTABLES=/sbin/iptables fi

$IPTABLES -A POSTROUTING -t nat -j MASQUERADE -s 192.168.7.0/24 echo 1 > /proc/sys/net/ipv4/ip_forward $IPTABLES -P FORWARD ACCEPT

echo $TAP