From: Keir Fraser Date: Mon, 11 Aug 2008 15:51:02 +0000 (+0100) Subject: xend/xenapi: Initialize a VLAN PIF's record with the MAC and MTU size X-Git-Tag: archive/raspbian/4.8.0-1+rpi1~1^2~14157^2~13 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=87122426932d27d494110515af31c676eccc77dc;p=xen.git xend/xenapi: Initialize a VLAN PIF's record with the MAC and MTU size of the created network interface Signed-off-by: Stefan Berger --- diff --git a/tools/python/xen/xend/XendPIF.py b/tools/python/xen/xend/XendPIF.py index ee39ec5413..2a2e78acc2 100644 --- a/tools/python/xen/xend/XendPIF.py +++ b/tools/python/xen/xend/XendPIF.py @@ -95,6 +95,22 @@ def linux_set_mtu(iface, mtu): except ValueError: return False +def linux_get_mtu(device): + return _linux_get_pif_param(device, 'mtu') + +def linux_get_mac(device): + return _linux_get_pif_param(device, 'link/ether') + +def _linux_get_pif_parm(device, param_name): + ip_get_dev_data = 'ip link show %s' % device + rc, output = commands.getstatusoutput(ip_get_dev_data) + if rc == 0: + params = output.split(' ') + for i in xrange(len(params)): + if params[i] == param_name: + return params[i+1] + return '' + def _create_VLAN(dev, vlan): rc, _ = commands.getstatusoutput('vconfig add %s %d' % (dev, vlan)) @@ -259,8 +275,8 @@ class XendPIF(XendBase): # Create the record record = { "device": device, - "MAC": '', - "MTU": '', + "MAC": linux_get_mac('%s.%d' % (device, vlan)), + "MTU": linux_get_mtu('%s.%d' % (device, vlan)), "network": network_uuid, "VLAN": vlan }