diff options
author | Scott Moser <smoser@brickies.net> | 2016-08-22 17:00:50 -0400 |
---|---|---|
committer | Scott Moser <smoser@brickies.net> | 2016-08-22 17:00:50 -0400 |
commit | c0c45eba28e623751d71a7fa3cb27c87300b851e (patch) | |
tree | 67fbb66105b1b81fa92240c59543962d716087e3 /cloudinit/net | |
parent | c13f800d19884a28c57745f692d1b5221c6c3a6c (diff) | |
parent | 40a2f621b05c11ed6397a1735b6bfff0ea07b097 (diff) | |
download | vyos-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__.py | 9 |
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): |