aboutsummaryrefslogtreecommitdiffstats
path: root/include/prereq-build.mk
Commit message (Expand)AuthorAgeFilesLines
* build: prereq: add support for Python 3.8Thomas Weißschuh2019-11-141-0/+2
* build: prereq: simplify Python 3 version checksPetr Štetiar2019-11-141-6/+6
* build: fix seq host tool checkJo-Philipp Wich2019-10-181-2/+2
* build: adjust gcc/g++ version checks for newer apple compilersFelix Fietkau2019-10-101-2/+2
* build: cleanup possibly dangling Python 2 host symlinkPetr Štetiar2019-07-261-0/+2
* build: switch to Python 3Petr Štetiar2019-07-261-4/+11
* build: fix umask detection bashismThorsten Glaser2019-01-301-1/+1
* build: remove GNU time dependencyJo-Philipp Wich2018-08-051-5/+0
* build: prereq-build.mk: fix gcc/g++ SetupHostCommand invocationJo-Philipp Wich2018-07-241-2/+2
* include/prereq-build.mk: explicitly check for -f flag when using busybox timeMatthias Schiffer2018-07-141-2/+2
* build: add busybox support to `time` prereq-checkAndy Boyett2018-06-181-2/+3
* build: log time taken by each packages/stepsEtienne Champetier2018-05-071-0/+4
* tools/zlib: move zlib build to toolsHauke Mehrtens2018-04-281-5/+0
* build: Improve GCC version detectionHauke Mehrtens2018-04-031-4/+8
* merge: etc: update remaining filesZoltan HERPAI2017-12-081-1/+1
* build: accept gcc/g++ without minor versionJustin Kilpatrick2017-11-261-4/+4
* toolchain: Test for supported versions of GCCDaniel Engberg2017-11-251-14/+18
* build: fix high cpu usage / hang in prereq-build.mkFelix Fietkau2017-03-181-1/+0
* build: get rid of host.mkFelix Fietkau2017-02-261-4/+3
* build: use mkhash to replace various quirky md5sum/openssl callsFelix Fietkau2017-01-051-5/+0
* build: add a small standalone utility for calculating md5/sha256 hashFelix Fietkau2017-01-051-0/+6
* tools: build libressl on all systemsFelix Fietkau2017-01-051-14/+0
* include: prereq-build.mk: improve gcp checkJo-Philipp Wich2016-10-111-2/+2
* include: remove XZ host prereqJo-Philipp Wich2016-10-061-3/+0
* include/prereq-build.mk: Add xz-utils to make prereqDaniel Engberg2016-10-051-0/+3
* include: relax umask checkJo-Philipp Wich2016-10-041-1/+1
* include: add umask prereq checkJo-Philipp Wich2016-10-041-0/+4
* build: do not depend on svn any moreHauke Mehrtens2016-07-311-3/+0
* build: allow to build LEDE on latest MacOS XWaldemar Brodkorb2016-06-071-0/+5
* branding: add LEDE brandingJohn Crispin2016-03-241-1/+1
* prereq: stop relying on man pages and grep for --recursive on the git-submodu...Felix Fietkau2016-03-051-1/+1
* build: fix git prereq check to forcibly disable man pagers on the --help checkFelix Fietkau2016-03-051-1/+1
* build: fix git prereq check to not rely on being in a git directory (#21968)Felix Fietkau2016-03-051-1/+1
* buildroot: improve git submodule handling for packagesFelix Fietkau2016-02-291-2/+2
* Support LibreSSL as provider of opensslFelix Fietkau2016-01-171-1/+1
* build: use host cflags/ldflags for openssl prereq checkFelix Fietkau2015-10-051-1/+1
* prereq-build: test availability of Perl Thread::Queue moduleJo-Philipp Wich2015-09-291-0/+4
* prereq-build: test for static zlib availabilityJo-Philipp Wich2015-09-161-2/+8
* include: remove trailing whitespacesLuka Perkov2015-03-291-1/+1
* build: accept apple llvm as fallback for gcc/g++Felix Fietkau2015-02-071-2/+4
* include: fix prereq tests for perl and file (#18911)Jo-Philipp Wich2015-02-061-2/+2
* include: rework git prereq test to not require 'man'Jo-Philipp Wich2015-02-061-1/+1
* include: remove static tool linking supportJo-Philipp Wich2015-02-061-18/+0
* include: set shell to "sh" for prereq testsJo-Philipp Wich2015-02-051-0/+1
* include: prereq-build.mk: use TestHostCommand and SetupHostCommandJo-Philipp Wich2015-02-051-150/+123
* prereq-build: rename the openssl check to libssl, add back the old check - it...Felix Fietkau2014-10-201-3/+7
* prereq-build: replace the openssl command check with a check for headersFelix Fietkau2014-10-201-2/+7
* build: clarify the file prereq check messageFelix Fietkau2014-04-241-1/+1
* build: add a prereq check for file (#15692)Felix Fietkau2014-04-241-0/+4
* Add package signing infrastructureSteven Barth2013-10-021-0/+4
span>addr:+append $mode "$vif"} ;; *) echo "$device($vif): Invalid mode, ignored."; continue;; esac done case "${adhoc:+1}:${sta:+1}:${ap:+1}" in # valid mode combinations 1::) wds="";; 1::1);; :1:1)config_set "$device" nosbeacon 1;; # AP+STA, can't use beacon timers for STA :1:);; ::1);; ::);; *) echo "$device: Invalid mode combination in config"; return 1;; esac config_set "$device" vifs "${sta:+$sta }${ap:+$ap }${adhoc:+$adhoc }${ahdemo:+$ahdemo }${wds:+$wds }${monitor:+$monitor}" } disable_atheros() ( local device="$1" set_wifi_down "$device" include /lib/network cd /proc/sys/net for dev in *; do grep "$device" "$dev/%parent" >/dev/null 2>/dev/null && { [ -f "/var/run/wifi-${dev}.pid" ] && kill "$(cat "/var/run/wifi-${dev}.pid")" ifconfig "$dev" down unbridge "$dev" wlanconfig "$dev" destroy } done return 0 ) enable_atheros() { local device="$1" # Can only set the country code to one setting for the entire system. The last country code is the one that will be applied. config_get country "$device" country [ -z "$country" ] && country="0" local cc="0" [ -e /proc/sys/dev/$device/countrycode ] && cc="$(cat /proc/sys/dev/$device/countrycode)" if [ ! "$cc" = "$country" ] ; then rmmod ath_pci insmod ath_pci countrycode=$country fi config_get channel "$device" channel config_get vifs "$device" vifs config_get txpower "$device" txpower [ auto = "$channel" ] && channel=0 local first=1 for vif in $vifs; do local start_hostapd vif_txpower nosbeacon= config_get ifname "$vif" ifname config_get enc "$vif" encryption config_get eap_type "$vif" eap_type config_get mode "$vif" mode case "$mode" in sta) config_get nosbeacon "$device" nosbeacon;; adhoc) config_get nosbeacon "$vif" sw_merge;; esac config_get ifname "$vif" ifname ifname=$(wlanconfig "$ifname" create wlandev "$device" wlanmode "$mode" ${nosbeacon:+nosbeacon}) [ $? -ne 0 ] && { echo "enable_atheros($device): Failed to set up $mode vif $ifname" >&2 continue } config_set "$vif" ifname "$ifname" # only need to change freq band and channel on the first vif config_get hwmode "$device" hwmode [ -z "$hwmode" ] && config_get hwmode "$device" mode pureg=0 case "$hwmode" in *b) hwmode=11b;; *bg) hwmode=11g;; *g) hwmode=11g; pureg=1;; *gdt) hwmode=11gdt;; *a) hwmode=11a;; *adt) hwmode=11adt;; *ast) hwmode=11ast;; *fh) hwmode=fh;; *) hwmode=auto;; esac iwpriv "$ifname" mode "$hwmode" iwpriv "$ifname" pureg "$pureg" [ "$first" = 1 ] && { iwconfig "$ifname" channel "$channel" >/dev/null 2>/dev/null } config_get_bool hidden "$vif" hidden 0 iwpriv "$ifname" hide_ssid "$hidden" config_get ff "$vif" ff if [ -n "$ff" ]; then iwpriv "$ifname" ff "$ff" fi config_get wds "$vif" wds case "$wds" in 1|on|enabled) wds=1;; *) wds=0;; esac iwpriv "$ifname" wds "$wds" [ "$mode" = ap -a "$wds" = 1 ] && { config_get_bool wdssep "$vif" wdssep 1 [ -n "$wdssep" ] && iwpriv "$ifname" wdssep "$wdssep" } case "$enc" in WEP|wep) for idx in 1 2 3 4; do config_get key "$vif" "key${idx}" iwconfig "$ifname" enc "[$idx]" "${key:-off}" done config_get key "$vif" key key="${key:-1}" case "$key" in [1234]) iwconfig "$ifname" enc "[$key]";; *) iwconfig "$ifname" enc "$key";; esac ;; psk*|wpa*) start_hostapd=1 config_get key "$vif" key ;; esac case "$mode" in adhoc|ahdemo) config_get addr "$vif" bssid [ -z "$addr" ] || { iwconfig "$ifname" ap "$addr" } ;; esac config_get ssid "$vif" ssid config_get_bool bgscan "$vif" bgscan [ -n "$bgscan" ] && iwpriv "$ifname" bgscan "$bgscan" config_get_bool antdiv "$device" diversity config_get antrx "$device" rxantenna config_get anttx "$device" txantenna config_get_bool softled "$device" softled 1 devname="$(cat /proc/sys/dev/$device/dev_name)" antgpio= case "$devname" in NanoStation2) antgpio=7;; NanoStation5) antgpio=1;; esac if [ -n "$antgpio" ]; then softled=0 config_get antenna "$device" antenna case "$antenna" in external) antdiv=0; antrx=1; anttx=1 ;; horizontal) antdiv=0; antrx=1; anttx=1 ;; vertical) antdiv=0; antrx=2; anttx=2 ;; auto) antdiv=1; antrx=0; anttx=0 ;; esac [ -x "$(which gpioctl 2>/dev/null)" ] || antenna= case "$antenna" in horizontal|vertical|auto) gpioctl "dirout" "$antgpio" >/dev/null 2>&1 gpioctl "set" "$antgpio" >/dev/null 2>&1 ;; external) gpioctl "dirout" "$antgpio" >/dev/null 2>&1 gpioctl "clear" "$antgpio" >/dev/null 2>&1 ;; esac fi [ -n "$antdiv" ] && sysctl -w dev."$device".diversity="$antdiv" >&- [ -n "$antrx" ] && sysctl -w dev."$device".rxantenna="$antrx" >&- [ -n "$anttx" ] && sysctl -w dev."$device".txantenna="$anttx" >&- [ -n "$softled" ] && sysctl -w dev."$device".softled="$softled" >&- config_get distance "$device" distance [ -n "$distance" ] && athctrl -i "$device" -d "$distance" >&- config_get rate "$vif" rate [ -n "$rate" ] && iwconfig "$ifname" rate "${rate%%.*}" config_get mcast_rate "$vif" mcast_rate [ -n "$mcast_rate" ] && iwpriv "$ifname" mcast_rate "${mcast_rate%%.*}" config_get frag "$vif" frag [ -n "$frag" ] && iwconfig "$ifname" frag "${frag%%.*}" config_get rts "$vif" rts [ -n "$rts" ] && iwconfig "$ifname" rts "${rts%%.*}" config_get_bool comp "$vif" compression [ -n "$comp" ] && iwpriv "$ifname" compression "$comp" config_get_bool minrate "$vif" minrate [ -n "$minrate" ] && iwpriv "$ifname" minrate "$minrate" config_get_bool maxrate "$vif" maxrate [ -n "$maxrate" ] && iwpriv "$ifname" maxrate "$maxrate" config_get_bool burst "$vif" bursting [ -n "$burst" ] && iwpriv "$ifname" burst "$burst" config_get_bool wmm "$vif" wmm [ -n "$wmm" ] && iwpriv "$ifname" wmm "$wmm" config_get_bool xr "$vif" xr [ -n "$xr" ] && iwpriv "$ifname" xr "$xr" config_get_bool ar "$vif" ar [ -n "$ar" ] && iwpriv "$ifname" ar "$ar" config_get_bool turbo "$vif" turbo [ -n "$turbo" ] && iwpriv "$ifname" turbo "$turbo" config_get_bool beacon_power "$vif" beacon_power [ -n "$beacon_power" ] && iwpriv "$ifname" beacon_pwr "$beacon_power" config_get_bool doth "$vif" doth 0 [ -n "$doth" ] && iwpriv "$ifname" doth "$doth" config_get_bool probereq "$vif" probereq [ -n "$probereq" ] && iwpriv "$ifname" probereq "$probereq" config_get maclist "$vif" maclist [ -n "$maclist" ] && { # flush MAC list iwpriv "$ifname" maccmd 3 for mac in $maclist; do iwpriv "$ifname" addmac "$mac" done } config_get macpolicy "$vif" macpolicy case "$macpolicy" in allow) iwpriv "$ifname" maccmd 1 ;; deny) iwpriv "$ifname" maccmd 2 ;; *) # default deny policy if mac list exists [ -n "$maclist" ] && iwpriv "$ifname" maccmd 2 ;; esac ifconfig "$ifname" up local net_cfg bridge net_cfg="$(find_net_config "$vif")" [ -z "$net_cfg" ] || { bridge="$(bridge_interface "$net_cfg")" config_set "$vif" bridge "$bridge" start_net "$ifname" "$net_cfg" } [ -n "$ssid" ] && iwconfig "$ifname" essid on iwconfig "$ifname" essid "$ssid" set_wifi_up "$vif" "$ifname" # TXPower settings only work if device is up already # while atheros hardware theoretically is capable of per-vif (even per-packet) txpower # adjustment it does not work with the current atheros hal/madwifi driver config_get vif_txpower "$vif" txpower # use vif_txpower (from wifi-iface) instead of txpower (from wifi-device) if # the latter doesn't exist txpower="${txpower:-$vif_txpower}" [ -z "$txpower" ] || iwconfig "$ifname" txpower "${txpower%%.*}" case "$mode" in ap) config_get_bool isolate "$vif" isolate 0 iwpriv "$ifname" ap_bridge "$((isolate^1))" if [ -n "$start_hostapd" ] && eval "type hostapd_setup_vif" 2>/dev/null >/dev/null; then hostapd_setup_vif "$vif" madwifi || { echo "enable_atheros($device): Failed to set up hostapd for interface $ifname" >&2 # make sure this wifi interface won't accidentally stay open without encryption ifconfig "$ifname" down wlanconfig "$ifname" destroy continue } fi ;; wds|sta) if eval "type wpa_supplicant_setup_vif" 2>/dev/null >/dev/null; then wpa_supplicant_setup_vif "$vif" madwifi || { echo "enable_atheros($device): Failed to set up wpa_supplicant for interface $ifname" >&2 ifconfig "$ifname" down wlanconfig "$ifname" destroy continue } fi ;; esac first=0 done } detect_atheros() { cd /proc/sys/dev [ -d ath ] || return for dev in $(ls -d wifi* 2>&-); do config_get type "$dev" type devname="$(cat /proc/sys/dev/$dev/dev_name)" case "$devname" in NanoStation*) EXTRA_DEV=" # Ubiquiti NanoStation features option antenna auto # (auto|horizontal|vertical|external) " ;; esac [ "$type" = atheros ] && return cat <<EOF config wifi-device $dev option type atheros option channel auto $EXTRA_DEV # REMOVE THIS LINE TO ENABLE WIFI: option disabled 1 config wifi-iface option device $dev option network lan option mode ap option ssid OpenWrt option encryption none EOF done }