poky/scripts/runqemu-gen-tapdevs
Chen Qi 11b81e3fba runqemu-gen-tapdevs: fix file path in example
Fix the path in example so that '/usr/bin/tunctl' could be found under
this path.

(From OE-Core rev: d1b8e1460b25018ac8f65d3647bc736f3393ed3e)

Signed-off-by: Chen Qi <Qi.Chen@windriver.com>
Signed-off-by: Ross Burton <ross.burton@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2017-03-24 23:43:32 +00:00

3.3 KiB
Executable File

#!/bin/bash

Create a "bank" of tap network devices that can be used by the

runqemu script. This script needs to be run as root, and will

use the tunctl binary from the build system 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 the build

system provided version.

Copyright (C) 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 "Usage: sudo $0 " echo "Where is the numeric user id the tap devices will be owned by" echo "Where is the numeric group id the tap devices will be owned by" echo " is the number of tap devices to create (0 to remove all)" echo " is the path to the build system's native sysroot" echo "e.g. $ bitbake qemu-helper-native" echo "$ sudo $0 1000 1000 4 tmp/sysroots-components/x86_64/qemu-helper-native/" exit 1 }

if [ $EUID -ne 0 ]; then echo "Error: This script must be run with root privileges" exit fi

if [ $# -ne 4 ]; then echo "Error: Incorrect number of arguments" usage fi

TUID=$1 GID=$2 COUNT=$3 SYSROOT=$4

TUNCTL=$SYSROOT/usr/bin/tunctl if ! -x "$TUNCTL" ; then echo "Error: $TUNCTL is not an executable" usage fi

SCRIPT_DIR=dirname $0 RUNQEMU_IFUP="$SCRIPT_DIR/runqemu-ifup" if [ ! -x "$RUNQEMU_IFUP" ]; then echo "Error: Unable to find the runqemu-ifup script in $SCRIPT_DIR" exit 1 fi

IFCONFIG=which ip 2> /dev/null if [ -z "$IFCONFIG" ]; then # Is it ever anywhere else? IFCONFIG=/sbin/ip fi if [ ! -x "$IFCONFIG" ]; then echo "$IFCONFIG cannot be executed" exit 1 fi

if [ $COUNT -ge 0 ]; then # Ensure we start with a clean slate for tap in $IFCONFIG link | grep tap | awk '{ print \$2 }' | sed s/://; do echo "Note: Destroying pre-existing tap interface $tap..." $TUNCTL -d $tap done rm -f /etc/runqemu-nosudo else echo "Error: Incorrect count: $COUNT" exit 1 fi

if [ $COUNT -gt 0 ]; then echo "Creating $COUNT tap devices for UID: $TUID GID: $GID..." for ((index=0; index < $COUNT; index++)); do echo "Creating tap$index" ifup=$RUNQEMU_IFUP $TUID $GID $SYSROOT 2>&1 if [ $? -ne 0 ]; then echo "Error running tunctl: $ifup" exit 1 fi done

echo "Note: For systems running NetworkManager, it's recommended"
echo "Note: that the tap devices be set as unmanaged in the"
echo "Note: NetworkManager.conf file. Add the following lines to"
echo "Note: /etc/NetworkManager/NetworkManager.conf"
echo "[keyfile]"
echo "unmanaged-devices=interface-name:tap*"

# The runqemu script will check for this file, and if it exists,
# will use the existing bank of tap devices without creating
# additional ones via sudo.
touch /etc/runqemu-nosudo

fi