From: Felix Fietkau Date: Wed, 19 Nov 2014 20:17:08 +0000 (+0000) Subject: mac80211: try to get interface addresses from wiphy sysfs 'addresses' if no mask... X-Git-Tag: reboot~5297 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=4d99db168cf7;p=oweals%2Fopenwrt.git mac80211: try to get interface addresses from wiphy sysfs 'addresses' if no mask is set Signed-off-by: Felix Fietkau SVN-Revision: 43326 --- diff --git a/package/kernel/mac80211/files/lib/netifd/wireless/mac80211.sh b/package/kernel/mac80211/files/lib/netifd/wireless/mac80211.sh index 918955a98a..d8fa07e225 100644 --- a/package/kernel/mac80211/files/lib/netifd/wireless/mac80211.sh +++ b/package/kernel/mac80211/files/lib/netifd/wireless/mac80211.sh @@ -326,6 +326,13 @@ ${max_listen_int:+max_listen_interval=$max_listen_int} EOF } +mac80211_get_addr() { + local phy="$1" + local idx="$(($2 + 1))" + + head -n $(($macidx + 1)) /sys/class/ieee80211/${phy}/addresses | tail -n1 +} + mac80211_generate_mac() { local phy="$1" local id="${macidx:-0}" @@ -333,7 +340,18 @@ mac80211_generate_mac() { local ref="$(cat /sys/class/ieee80211/${phy}/macaddress)" local mask="$(cat /sys/class/ieee80211/${phy}/address_mask)" - [ "$mask" = "00:00:00:00:00:00" ] && mask="ff:ff:ff:ff:ff:ff"; + [ "$mask" = "00:00:00:00:00:00" ] && { + mask="ff:ff:ff:ff:ff:ff"; + + [ "$(wc -l < /sys/class/ieee80211/${phy}/addresses)" -gt 1 ] && { + addr="$(mac80211_get_addr "$phy" "$id")" + [ -n "$addr" ] && { + echo "$addr" + return + } + } + } + local oIFS="$IFS"; IFS=":"; set -- $mask; IFS="$oIFS" local mask1=$1