Wi-Fi
The Wi-Fi function in the Wiren Board controller can be configured to operate in one of two or three modes:
- hotspot mode (enabled by default);
- client mode;
- simultaneous operation in both modes(only in some versions of the controller; see below for details).
First Wi-Fi connection
- Connect antenna to the Wi-Fi connector.
- The Wiren Board Wi-Fi is available at a distance of no more than one meter without the antenna.To get a standart Wi-Fi radius of operation, you need to connect antenna to the appropriate connector of the controller. If the controller is in the closet(especially in a metal one) or a separate room, it is better to use a remote antenna.
- The antenna has standart Wi-Fi connector: RP-SMA (differs from SMA-connector for GSM antennas)RP-SMA
- Wiren Board controller's WI-Fi works in hotspot mode by default:
- hotspot name: WirenBoard...
- password: none
- adress of the controller in the created network: 192.168.42.1
\Wi-Fi configuration in Linux
The configuration is usually proceed in a standart way for Linux Debian: via file /etc/network/interfaces
. The following are brief instructions for common tasks on Linux Debian, there is a detailed documentation on the Linux site. detailed documentation.
Setting in a hotspot mode
Access point mode is enabled by default. Operation in the access point mode is provided by the hostapd daemon.
Процесс настройки:
- Включите режим точки доступа. Для этого:
- в файле
/etc/default/hostapd
раскомментируйте строку (то есть удалите знак # в начале строки)DAEMON_CONF="/etc/hostapd.conf"
- отредактируйте файл
/etc/hostapd.conf
, чтобы он выглядел так:interface=wlan0 #driver=nl80211 # оставьте эту строку закомментированной ssid=WirenBoard # вместо WirenBoard можете подставить другое имя для создаваемой точки доступа channel=1 wpa=2 wpa_passphrase=your_password # вместо your_password подставьте пароль wpa_key_mgmt=WPA-PSK wpa_pairwise=TKIP CCMP rsn_pairwise=TKIP CCMP
- в файле
- Отредактируйте
/etc/network/interfaces
:- раскомментируйте и отредактируйте (или добавьте, если их не было) строки, относящиеся к настройке в режиме точки доступа:
iface wlan0 inet static address 192.168.42.1 # здесь 192.168.42.1 - адрес, по которому в новой сети будет находиться Wiren Board; можете указать другой адрес netmask 255.255.255.0
- закомментируйте строки, относящиеся к работе в режиме клиента:
#auto wlan0 #iface wlan0 inet dhcp # wpa-ssid {ssid} # wpa-psk {password}
- раскомментируйте и отредактируйте (или добавьте, если их не было) строки, относящиеся к настройке в режиме точки доступа:
- Выполните команду
/etc/init.d/hostapd restart
Настройка в режиме клиента
- Отключите режим точки доступа.
- Для этого в файле
/etc/default/hostapd
закомментируйте строку (то есть добавьте знак # в начало строки)#DAEMON_CONF="/etc/hostapd.conf"
- Для этого в файле
- Отредактируйте
/etc/network/interfaces
:- закомментируйте строки, относящиеся к настройке в режиме точки доступа:
#iface wlan0 inet static # address 192.168.42.1 # netmask 255.255.255.0
- раскомментируйте и отредактируйте строки (или добавьте, если их не было):
auto wlan0 iface wlan0 inet dhcp wpa-ssid {ssid} # вместо {ssid} подставьте имя точки доступа wpa-psk {password} # вместо {password} подставьте пароль
- закомментируйте строки, относящиеся к настройке в режиме точки доступа:
- Чтобы применить изменения, выполните команды
ifdown wlan0
ifup wlan0
Настройка в режиме точки доступа и клиента одновременно
Режим одновременной работы модуля Wi-Fi и в режиме точки доступа, и в режиме клиента, называется Concurrent Mode или STA+SoftAP, и поддерживается не всеми Wi-Fi модулями. Также он работает не на всех версиях Wiren Board. Проверено, что он работает из коробки на Wiren Board с чипом Realtek 8723BU и ядром Linux 4.1.15. Чтобы проверить, выполняются ли эти условия, выполните команды:
uname -a
lsmod | grep 8723bu
Если условия не выполнены, возможно, на вашем Wiren Board всё равно можно настроить Concurrent Mode. В качестве отправной точки используйте инструкцию.
Если условия выполнены:
- Выполните команду
iwconfig
- В её выводе должны быть показаны два интерфейса Wi-Fi: wlan0 и wlan1.
- Настройте по двум предыдущим инструкциям подключение в режиме клиента и подключение в режиме точки доступа, но используйте для них разные интерфейсы. Например, оставьте wlan0 для точки доступа, а клиента сделайте на wlan1. Соответствующая часть файла /etc/network/interfaces должна выглядеть так:
# Wireless interfaces auto wlan1 iface wlan1 inet dhcp wpa-ssid {ssid} # вместо {ssid} подставьте имя точки доступа wpa-psk {password} # вместо {password} подставьте пароль auto wlan0 iface wlan0 inet static address 192.168.42.1 netmask 255.255.255.0
Универcальный файл настроек Wi-Fi
Ниже дан текст файла, в котором показаны настройки для подключения к сетям с разными параметрами шифрования. Файл позаимствован здесь.
####################
#; start of wireless bits
#; this command stays for all configs
auto wlan0
###################
#; comments indicated by #;
#; commands indicated by #
#; remove the # to enable the command
####################
#; if using static IP then....#
#iface wlan0 inet static
# address UR_IP
#gateway UR_ROUTER_IP
#netmask 255.255.255.0
##################
#; otherwise use dhcp #
#iface wlan0 inet dhcp
###################
#; OPEN wireless config #
#wireless-essid UR_ESSID
#wireless-mode managed
###################
#; WEP wireless config #
#wireless-essid UR_ESSID
#wireless-key UR_KEY
#; end of WEP config
########################
#; WPA and WPA2 wireless config #
#; all command config lines above HERE to be #'ed except the entry auto wlan0
########################
wpa-driver wext
wpa-ssid UR_ESSID
#; wpa-ap-scan is 1 for visible and 2 for hidden hubs
wpa-ap-scan 1
#; wpa-proto is WPA for WPA1 (aka WPA) or RSN for WPA2
wpa-proto WPA
#; wpa-pairwise and wpa-group is TKIP for WPA1 or CCMP for WPA2
wpa-pairwise TKIP
wpa-group TKIP
wpa-key-mgmt WPA-PSK
#; use "wpa_passphrase UR_ESSID UR_KEY" to generate UR_HEX_KEY
#; enter the result below
wpa-psk UR_HEX_KEY
##########################
# end of wireless bits
Автоматическое переподключение при проблемах с соединением
Способ заимствован здесь: [1]
Допустим, контроллер подключён к роутеру с адресом 192.168.0.1 через интерфейс wlan1. Тогда:
- Создайте в папке
/root
скриптwifi_autoconnect.sh
с содержанием:#!/bin/bash # Подставьте имя интерфейса WLANINTERFACE=wlan1 # Подставьте адрес роутера или сервера в интернете, доступ к которому будет проверяться SERVER=192.168.0.1 # Only send two pings, sending output to /dev/null ping -I ${WLANINTERFACE} -c2 ${SERVER} > /dev/null # If the return code from ping ($?) is not 0 (meaning there was an error) if [ $? != 0 ] then # Restart the wireless interface ifdown --force ${WLANINTERFACE} ifup ${WLANINTERFACE} fi
- Сделайте файл исполняемым, выполнив команду
chmod +x /root/wifi_autoconnect.sh
- Запланируйте выполнение скрипта каждую минуту. Для этого:
- Установите cron:
apt-get install cron
- Добавьте в конец файла
/etc/crontab
строку* * * * * root /root/wifi_autoconnect.sh # обязательно добавьте пустую строку в конец файла
- Установите cron:
Ограничения
- Wi-Fi в Wiren Board в режиме точки доступа работает относительно медленно. Скорости вполне хватит для работы с веб-интерфейсом, но не стоит использовать Wiren Board в качестве замены роутера.
- В очень редких случаях возможна несовместимость адаптера Wi-Fi в Wiren Board с некоторыми другими устройствами Wi-Fi. Это общая проблема реализаций Wi-Fi на чипсетах разных производителей. Если вы столкнулись с необъяснимыми проблемами при работе, рекомендуем поменять настройки шифрования, ширины канала и т.п.