summaryrefslogtreecommitdiff
path: root/cloudinit/net
diff options
context:
space:
mode:
authorScott Moser <smoser@brickies.net>2016-08-22 17:00:50 -0400
committerScott Moser <smoser@brickies.net>2016-08-22 17:00:50 -0400
commitc0c45eba28e623751d71a7fa3cb27c87300b851e (patch)
tree67fbb66105b1b81fa92240c59543962d716087e3 /cloudinit/net
parentc13f800d19884a28c57745f692d1b5221c6c3a6c (diff)
parent40a2f621b05c11ed6397a1735b6bfff0ea07b097 (diff)
downloadvyos-cloud-init-c0c45eba28e623751d71a7fa3cb27c87300b851e.tar.gz
vyos-cloud-init-c0c45eba28e623751d71a7fa3cb27c87300b851e.zip
merge from master at 0.7.7-17-g40a2f62
Diffstat (limited to 'cloudinit/net')
-rw-r--r--cloudinit/net/__init__.py9
1 files changed, 7 insertions, 2 deletions
diff --git a/cloudinit/net/__init__.py b/cloudinit/net/__init__.py
index 21cc602b..7e58bfea 100644
--- a/cloudinit/net/__init__.py
+++ b/cloudinit/net/__init__.py
@@ -36,7 +36,7 @@ def read_sys_net(devname, path, translate=None, enoent=None, keyerror=None):
try:
contents = util.load_file(sys_dev_path(devname, path))
except (OSError, IOError) as e:
- if getattr(e, 'errno', None) == errno.ENOENT:
+ if getattr(e, 'errno', None) in (errno.ENOENT, errno.ENOTDIR):
if enoent is not None:
return enoent
raise
@@ -347,7 +347,12 @@ def _rename_interfaces(renames, strict_present=True, strict_busy=True,
def get_interface_mac(ifname):
"""Returns the string value of an interface's MAC Address"""
- return read_sys_net(ifname, "address", enoent=False)
+ path = "address"
+ if os.path.isdir(sys_dev_path(ifname, "bonding_slave")):
+ # for a bond slave, get the nic's hwaddress, not the address it
+ # is using because its part of a bond.
+ path = "bonding_slave/perm_hwaddr"
+ return read_sys_net(ifname, path, enoent=False)
def get_interfaces_by_mac(devs=None):