mac80211: use board.json provided phy names in generated default config
The phy will be automatically renamed on setup Signed-off-by: Felix Fietkau <nbd@nbd.name>
This commit is contained in:
parent
50a03decdf
commit
a7ca1b2314
@ -2,58 +2,46 @@
|
|||||||
|
|
||||||
append DRIVERS "mac80211"
|
append DRIVERS "mac80211"
|
||||||
|
|
||||||
lookup_phy() {
|
check_mac80211_device() {
|
||||||
[ -n "$phy" ] && {
|
|
||||||
[ -d /sys/class/ieee80211/$phy ] && return
|
|
||||||
}
|
|
||||||
|
|
||||||
local devpath
|
|
||||||
config_get devpath "$device" path
|
|
||||||
[ -n "$devpath" ] && {
|
|
||||||
phy="$(iwinfo nl80211 phyname "path=$devpath")"
|
|
||||||
[ -n "$phy" ] && return
|
|
||||||
}
|
|
||||||
|
|
||||||
local macaddr="$(config_get "$device" macaddr | tr 'A-Z' 'a-z')"
|
|
||||||
[ -n "$macaddr" ] && {
|
|
||||||
for _phy in /sys/class/ieee80211/*; do
|
|
||||||
[ -e "$_phy" ] || continue
|
|
||||||
|
|
||||||
[ "$macaddr" = "$(cat ${_phy}/macaddress)" ] || continue
|
|
||||||
phy="${_phy##*/}"
|
|
||||||
return
|
|
||||||
done
|
|
||||||
}
|
|
||||||
phy=
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
find_mac80211_phy() {
|
|
||||||
local device="$1"
|
local device="$1"
|
||||||
|
local path="$2"
|
||||||
|
local macaddr="$3"
|
||||||
|
|
||||||
|
[ -n "$found" ] && return 0
|
||||||
|
|
||||||
|
phy_path=
|
||||||
config_get phy "$device" phy
|
config_get phy "$device" phy
|
||||||
lookup_phy
|
json_select wlan
|
||||||
[ -n "$phy" -a -d "/sys/class/ieee80211/$phy" ] || {
|
[ -n "$phy" ] && case "$phy" in
|
||||||
echo "PHY for wifi device $1 not found"
|
phy*)
|
||||||
return 1
|
[ -d /sys/class/ieee80211/$phy ] && \
|
||||||
}
|
phy_path="$(iwinfo nl80211 path "$dev")"
|
||||||
config_set "$device" phy "$phy"
|
;;
|
||||||
|
*)
|
||||||
config_get macaddr "$device" macaddr
|
if json_is_a "$phy" object; then
|
||||||
[ -z "$macaddr" ] && {
|
json_select "$phy"
|
||||||
config_set "$device" macaddr "$(cat /sys/class/ieee80211/${phy}/macaddress)"
|
json_get_var phy_path path
|
||||||
}
|
json_select ..
|
||||||
|
elif json_is_a "${phy%.*}" object; then
|
||||||
|
json_select "${phy%.*}"
|
||||||
|
json_get_var phy_path path
|
||||||
|
json_select ..
|
||||||
|
phy_path="$phy_path+${phy##*.}"
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
json_select ..
|
||||||
|
[ -n "$phy_path" ] || config_get phy_path "$device" path
|
||||||
|
[ -n "$path" -a "$phy_path" = "$path" ] && {
|
||||||
|
found=1
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
check_mac80211_device() {
|
config_get dev_macaddr "$device" macaddr
|
||||||
config_get phy "$1" phy
|
|
||||||
[ -z "$phy" ] && {
|
[ -n "$macaddr" -a "$dev_macaddr" = "$macaddr" ] && found=1
|
||||||
find_mac80211_phy "$1" >/dev/null || return 0
|
|
||||||
config_get phy "$1" phy
|
return 0
|
||||||
}
|
|
||||||
[ "$phy" = "$dev" ] && found=1
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -144,20 +132,32 @@ check_devidx() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
check_board_phy() {
|
||||||
|
local name="$2"
|
||||||
|
|
||||||
|
json_select "$name"
|
||||||
|
json_get_var phy_path path
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
if [ "$path" = "$phy_path" ]; then
|
||||||
|
board_dev="$name"
|
||||||
|
elif [ "${path%+*}" = "$phy_path" ]; then
|
||||||
|
fallback_board_dev="$name.${path#*+}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
detect_mac80211() {
|
detect_mac80211() {
|
||||||
devidx=0
|
devidx=0
|
||||||
config_load wireless
|
config_load wireless
|
||||||
config_foreach check_devidx wifi-device
|
config_foreach check_devidx wifi-device
|
||||||
|
|
||||||
|
json_load_file /etc/board.json
|
||||||
|
|
||||||
for _dev in /sys/class/ieee80211/*; do
|
for _dev in /sys/class/ieee80211/*; do
|
||||||
[ -e "$_dev" ] || continue
|
[ -e "$_dev" ] || continue
|
||||||
|
|
||||||
dev="${_dev##*/}"
|
dev="${_dev##*/}"
|
||||||
|
|
||||||
found=0
|
|
||||||
config_foreach check_mac80211_device wifi-device
|
|
||||||
[ "$found" -gt 0 ] && continue
|
|
||||||
|
|
||||||
mode_band=""
|
mode_band=""
|
||||||
channel=""
|
channel=""
|
||||||
htmode=""
|
htmode=""
|
||||||
@ -165,15 +165,26 @@ detect_mac80211() {
|
|||||||
|
|
||||||
get_band_defaults "$dev"
|
get_band_defaults "$dev"
|
||||||
|
|
||||||
|
path="$(iwinfo nl80211 path "$dev")"
|
||||||
|
macaddr="$(cat /sys/class/ieee80211/${dev}/macaddress)"
|
||||||
|
board_dev=
|
||||||
|
fallback_board_dev=
|
||||||
|
json_for_each_item check_board_phy wlan
|
||||||
|
[ -n "$board_dev" ] || board_dev="$fallback_board_dev"
|
||||||
|
[ -n "$board_dev" ] && dev="$board_dev"
|
||||||
|
|
||||||
|
found=
|
||||||
|
config_foreach check_mac80211_device wifi-device "$path" "$macaddr"
|
||||||
|
[ -n "$found" ] && continue
|
||||||
|
|
||||||
name="radio${devidx}"
|
name="radio${devidx}"
|
||||||
devidx=$(($devidx + 1))
|
devidx=$(($devidx + 1))
|
||||||
case "$dev" in
|
case "$dev" in
|
||||||
phy*)
|
phy*)
|
||||||
path="$(iwinfo nl80211 path "$dev")"
|
|
||||||
if [ -n "$path" ]; then
|
if [ -n "$path" ]; then
|
||||||
dev_id="set wireless.${name}.path='$path'"
|
dev_id="set wireless.${name}.path='$path'"
|
||||||
else
|
else
|
||||||
dev_id="set wireless.${name}.macaddr=$(cat /sys/class/ieee80211/${dev}/macaddress)"
|
dev_id="set wireless.${name}.macaddr='$macaddr'"
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user