Add bind-mount for /etc/adjtime to make subhost use host clock without ado
[rrq/overlay-boot.git] / functions
index 2fa68ccf2de35cad8232b355ab57f6a849d1fcb2..8f39d4014e9213a56c63f4dc03b228f94e73c5ce 100644 (file)
--- a/functions
+++ b/functions
@@ -92,6 +92,9 @@ EOF
 
 # Setup the network namespace for the given $CABLES
 # $1=netns ( $2="br=mac" .. )
+# br is optional, mac is optional.
+# If mac is .N then it's taken as vlan tag on prior outer interface
+# (with ifup configuration) and the inner interface is left alone.
 setup_veth_cables() {
     local NETNS BR IF MAC C i ADD
     NETNS="$1"
@@ -100,14 +103,29 @@ setup_veth_cables() {
     for C in "$@" ; do
        IF=$NETNS$i
        MAC="${C#*=}"
-       [ -z "$MAC" ] || MAC="address $MAC"
-       ip link add $IF type veth peer name eth$i $MAC netns $NETNS
-       ip link set $IF up
+        if ip link show $IF > /dev/null 2>&1 ; then
+           : # The interface exists already (bad badness); let things fail
+        elif ifquery --state $IF >/dev/null 2>&1 ; then
+            # doesn't exist but has residue state; quiet cleanup
+            ifdown -f $IF > /dev/null 2>&1
+        fi
+       if [ -z "$MAC" ] ; then
+           # set up veth with "random" mac address
+           ip link add $IF type veth peer name eth$i netns $NETNS
+       elif [ -z "${MAC%%.*}" ] ; then
+           # set up a host vlan with specified tag on previous eth 
+           i=$((i-1))
+           IF=$NETNS$i$MAC
+           ifup $IF
+       else
+           # set up veth with specified mac address
+           ip link add $IF type veth peer name eth$i address $MAC netns $NETNS
+       fi
        BR="${C%=*}"
        if [ -z "$BR" ] ; then
-           ip link set $IF
-           ifup $IF
+           ifup $IF || ip link set $IF up
        else
+           ip link set $IF up
            brctl addif $BR $IF
        fi
        i=$((i+1))
@@ -151,7 +169,7 @@ setup_overlay() {
     elif [ "$LIVE" != "$UPPER" ] ; then
        # With UPPER = LOWER we rather make a bind mount to LIVE
        env CONFIG="$CONFIG" $PREMOUNT "$UPPER"
-       mount --bind $UPPER $LOWER
+       mount --bind $UPPER $LIVE
     fi
 
     grep ^SHARE= "$CONFIG" | while read A ; do