|
|
(не показано 257 промежуточных версий 11 участников) |
Строка 1: |
Строка 1: |
| {{DISPLAYTITLE: Настройка 2G/3G/NB-IOT модемов в контроллере Wiren Board, а также 4G-модемов на Debian Stretch }}
| | В Wiren Board установлен GSM/GPRS-модуль [[SIM900R]], с помощью которого можно: |
| == Общая информация ==
| | * отправлять СМС |
| {{note|info|Эта статья описывает настройку 2G/3G/NB-IOT модемов в контроллерах Wiren Board 5...7, а также 4G(LTE)-модема в релизе [[wb-2207]] и старее. Для настройки 4G(LTE)-модема в релизе [[wb-2304]] и новее, используйте эту [[Modem-bullseye|инструкцию]].}}
| | * принимать СМС |
| В контроллеры Wiren Board могут быть установлены 2G/3G/4G(LTE)/NB-IOT модемы — зависит от комплектации.
| | * устанавливать соединение с интернетом |
| | Полный список возможностей смотрите в [[SIM900R | описании модуля]]. |
|
| |
|
| С помощью модемов можно:
| | == Работа из Linux == |
| * [[#Работа с sms и ussd | отправлять и принимать SMS]],
| | Внутри контроллера модем подключён к процессору по двухпроводному последовательному порту (UART). В Linux этот порт отображается как псевдоустройство '''/dev/ttyAPP0''' (первый порт (Application UART) процессора). Модуль управляется посредством передачи команд на этот порт. |
| * подключаться к интернету по [[#Интернет через PPP|протоколу PPP]] для 2G- и 3G-модемов, а также настраивать 4G-модем как [[#Интернет с 4G-модемом (LTE)|сетевую карту]] с выходом в интернет.
| |
|
| |
|
| Модемы подключаются к процессору по uart и usb, исключение — модемы 2G.
| | Кроме того, модуль можно выключить и перезагрузить, подав сигналы на контакты модуля PWRKEY и RESET. Для этих целей написана простая утилита '''wb-gsm''' (примеры использования смотрите ниже). Прямой доступ к этим контактам реализован через GPIO (подробнее читайте [[GPIO]], ищите в таблице соответствующие названия). |
| Подробнее о подключении модемов и низкоуровневом взаимодействии с ними можно почитать в разделе [[#Низкоуровневая работа по uart|Низкоуровневая работа по uart]].
| |
|
| |
|
| Управление питанием и переключением активных sim-карт (если их две) производится с помощью gpio, процесс описан в разделе [[#Переключение активной sim-карты | Переключение активной sim-карты]].
| | === Включение модуля === |
| | Для включения или перезагрузки модуля можно пользоваться утилитой wb-gsm из репозитория https://github.com/contactless/wirenboard . |
|
| |
|
| Включение и отключение модема рекомендуем делать с помощью утилиты [[#Утилита wb-gsm|wb-gsm]].
| | Примеры: |
|
| |
|
| == Получение информации о модеме ==
| | <pre> |
| | $ wb-gsm on # включение устройства |
| | $ wb-gsm off # выключение устройства |
| | </pre> |
|
| |
|
| В контроллерах, начиная с 2019 года, некоторая информация о модеме заносится в память. Получить её можно с помощью чтения файлов в директории <code>/proc/device-tree/wirenboard/gsm/</code>.
| | <pre> |
| | $ wb-gsm reset # перезагрузка включенного устройства |
| | </pre> |
|
| |
|
| В контроллерах версии 6.7 модем устанавливается модулем расширения.
| | === Работа с модулем === |
| {{Wbincludes:Configuration WBC}}
| | Ознакомьтесь с инструкцией [[Работа с последовательным портом из Linux]] |
|
| |
|
| Например, чтобы узнать модель модема, нужно выполнить команду
| | Для интерактивного режима: |
| <syntaxhighlight lang="bash"> | | * запускаем '''minicom''' с ключём, создающим профиль работы с портом (скорость передачи данных, чётность, и т.д.): |
| cat /proc/device-tree/wirenboard/gsm/model
| | <pre> |
| </syntaxhighlight>
| | $ minicom -s /dev/ttyAPP0 |
| | </pre> |
| | * Зайти в настройки (нажать ''Ctrl+A'', затем ''O''), выбрать пункт ''Serial port setup'', там установить порт ''/dev/ttyAPP0'', скорость и чётность - ''115200, 8N1'', ''Hardware flow control - No'', ''Software flow control - No'' |
| | * Сохранить настройки: ''Save setup as _dev_ttyAPP0'' |
| | * Далее запускать как '''minicom /dev/ttyAPP0''' (все параметры будут сразу браться из профиля с названием ''/dev/ttyAPP0'', который мы ранее создали) |
| | * Первой вашей командой должна стать ''AAAAAAAAAT'' - с её помощью модуль распознает скорость, с которой мы к нему обращаемся (смотрите [[SIM900R]]) |
| | * Второй командой выполните просто ''AT''. Вам должен прийти ответ '''OK''' |
|
| |
|
| Подробнее о файлах внутри директории можно узнать из таблицы:
| | === Примеры команд === |
| {| class="wikitable"
| | * Синхронизовать скорость порта (не совсем команда) |
| !Файл||Описание
| | <pre> |
| |-
| | AAAAAAAAAAAAAT |
| ||/proc/device-tree/wirenboard/gsm/model||модель модема
| | </pre> |
| |-
| | * Список всех сетей |
| ||/proc/device-tree/wirenboard/gsm/type||поддерживаемые сети
| | <pre> |
| |-
| | AT+COPS=? |
| ||/proc/device-tree/wirenboard/gsm/status||статус модема в системе
| | </pre> |
| |}
| | * Уровень сигнала (см. http://m2msupport.net/m2msupport/atcsq-signal-quality/) |
| | <pre> |
| | AT+CSQ |
| | </pre> |
| | * Звонок на номер +79154816100 |
| | <pre> |
| | ATD+79154816100; |
| | </pre> |
| | * Установка baud rate порта в фиксированное значение 115200 |
| | <pre> |
| | AT+IPR=115200 |
| | </pre> |
|
| |
|
| == Включение и начало работы ==
| | * Запрос времени со встроенных в модуль часов реального времени (RTC) |
| Чтобы начать работу с модемом, нужно:
| | <pre> |
| #[[SIM_card_installation | Вставьте sim-карту]].
| | AT+CCLK? |
| #Подключите антенну.
| | AT+CCLK="14/03/19,01:20:29+00" |
| #Перезапустите модем, выполнив команду
| | </pre> |
| #:<syntaxhighlight lang="bash">
| |
| wb-gsm restart_if_broken
| |
| </syntaxhighlight> | |
|
| |
|
| После каждой смены sim-карты необходимо перезапускать модем.
| | * Получить IMEI-код модуля (xxxxxx - уникальный номер) |
| | | <pre> |
| == Утилита wb-gsm ==
| | AT+GSN |
| | | 86820400xxxxxxY |
| Для упрощения работы с модемами была написана утилита <code>wb-gsm</code>, которая входит в пакет [https://github.com/wirenboard/wb-utils wb-utils].
| |
| | |
| Утилита <code>wb-gsm</code> входит в состав пакета <code>wb-utils</code>, который предустановлен на все контроллеры Wiren Board.
| |
| | |
| С помощью <code>wb-gsm</code> вы сможете:
| |
| * управлять питанием модемов, команды <code>on, off, restart_if_broken</code>;
| |
| * настраивать baudrate связи по uart, команды <code>init_baud, set_speed</code>; | |
| * получать imei, команда <code>imei</code>.
| |
| | |
| Все команды wb-gsm можно посмотреть в репозитории на Github по ссылке в начале раздела.
| |
| | |
| Пример использования утилиты <code>wb-gsm</code> для получения imei модема, флаг <code>DEBUG=true</code> — выводить отладочную информацию:
| |
| <syntaxhighlight lang="bash">
| |
| DEBUG=true wb-gsm imei
| |
| </syntaxhighlight>
| |
| | |
| == Переключение активной sim-карты ==
| |
| | |
| По умолчанию активна Sim1 — в каждый момент времени '''только одна sim-карта может быть активной'''.
| |
| | |
| Переключить модем на другую sim-карту можно с помощью gpio процессора. Узнать его номер можно двумя способами:
| |
| *выполнить команду <syntaxhighlight lang="bash">echo $WB_GPIO_GSM_SIMSELECT</syntaxhighlight>
| |
| *найти ''SIM Slot Select gpio'' в [[Wiren_Board_6.1:Список_GPIO#Ножки для внутреннего использования|таблице gpio]] контроллера.
| |
| | |
| По умолчанию, этот gpio уже экспортирован в sysfs, поэтому, для переключения активной sim-карты с 1 на 2, нужно выполнить команду (в примере, номер gpio для переключения sim-карт - 88): <syntaxhighlight lang="bash">echo 1 > /sys/class/gpio/gpio88/value</syntaxhighlight> Соответственно, для переключения обратно на sim1, нужно записать 0.
| |
| Подробнее о работе с gpio можно узнать из статьи [[Работа_с_GPIO#Интерфейс sysfs в Linux|Работа_с_GPIO]].
| |
| | |
| Для того чтобы новая sim-карта стала активной, нужно '''выполнить следующие AT-команды''' (см. [[#Отправка AT-команд|раздел о работе с AT-командами]]):
| |
| <syntaxhighlight lang="bash">
| |
| AT+CFUN=0
| |
| AT+CFUN=1
| |
| </syntaxhighlight>
| |
| | |
| == Низкоуровневая работа по uart ==
| |
| | |
| Любое взаимодействие с модемом так или иначе сводится к отправке AT-команд через последовательный порт модема. Все модемы подключаются к порту <code>/dev/ttyGSM</code>. 3G модемы, помимо этого, подключаются к портам ''/dev/ttyACM'''X''''' (порты создаются usb-драйвером <code>cdc_acm</code>).
| |
| | |
| === Подключение в linux ===
| |
| | |
| *uart: Порт <code>/dev/ttyGSM</code> является ссылкой на ''/dev/ttymxc'''X''''' (uart процессора) и создается с помощью правил udev. Конечный порт может быть разным для разных версий контроллера (подробнее можно посмотреть на [https://github.com/wirenboard/wb-configs/tree/master/configs/usr/share/wb-configs/udev нашем github]).
| |
| | |
| *usb: Порты ''/dev/ttyUSB'''X''''' или ''/dev/ttyACM'''X''''' (в случае 3G-модема) появляются автоматически после подачи питания на модем. Обычно, порты 3G-модема — это <code>/dev/ttyACM0-6</code>, однако '''точно''' определить, к каким портам модем подключен по USB можно, выполнив команды: <syntaxhighlight lang="bash">wb-gsm restart_if_broken; dmesg | tail</syntaxhighlight>.
| |
| | |
| Примерный вывод команды:
| |
| <syntaxhighlight lang="bash">
| |
| [ 6102.978383] usb 2-1.2: New USB device found, idVendor=1e0e, idProduct=0020
| |
| [ 6102.985653] usb 2-1.2: New USB device strings: Mfr=1, Product=2, SerialNumber=3
| |
| [ 6102.993108] usb 2-1.2: Product: SIMCOM_PRODUCT
| |
| [ 6102.997728] usb 2-1.2: Manufacturer: SIMCOM_VENDOR
| |
| [ 6103.002644] usb 2-1.2: SerialNumber: 004999010640000
| |
| [ 6103.082093] cdc_acm 2-1.2:1.0: ttyACM0: USB ACM device
| |
| [ 6103.098228] cdc_acm 2-1.2:1.2: ttyACM1: USB ACM device
| |
| [ 6103.116769] cdc_acm 2-1.2:1.4: ttyACM2: USB ACM device
| |
| [ 6103.132688] cdc_acm 2-1.2:1.6: ttyACM3: USB ACM device
| |
| [ 6103.145157] cdc_acm 2-1.2:1.8: ttyACM4: USB ACM device
| |
| [ 6103.163705] cdc_acm 2-1.2:1.10: ttyACM5: USB ACM device
| |
| [ 6103.182338] cdc_acm 2-1.2:1.12: ttyACM6: USB ACM device
| |
| </syntaxhighlight>
| |
| Соответственно, в данном случае 3G модем подключен к портам <code>/dev/ttyACM0 - /dev/ttyACM6</code>.
| |
| | |
| === Отправка AT-команд ===
| |
| [[Image: Minicom-AT-4G.png |500px|thumb|right| Отправка AT-комманд для модема в терминале программы [[minicom]]]]
| |
| | |
| {{Wbincludes:GSM Modem Default Connection Parameters}}
| |
| | |
| Для работы в интерактивном режиме рекомендуем использовать утилиту [[minicom]]:
| |
| {{Wbincludes:GSM Modem AT Prepare}}
| |
| Модем готов к передаче AT-команд.
| |
| | |
| Чтобы закрыть minicom, нажмите на клавиатуре клавиши <kbd>Ctrl</kbd>+<kbd>A</kbd>, затем клавишу <kbd>X</kbd> и подтвердите выход клавишей <kbd>Enter</kbd>.
| |
| | |
| == Работа с sms и ussd ==
| |
| | |
| Работать с sms и ussd проще всего при помощи программы [http://wammu.eu/gammu/ ''Gammu''] (это форк утилиты <code>gnokii</code>, которую перестали развивать).
| |
| | |
| Полную документацию смотрите на сайте проекта, ниже дана краткая инструкция.
| |
| | |
| === Настройка ===
| |
| | |
| Все контроллеры WB6, начиная с 2018 года, поставляются с уже настроенной утилитой gammu. Если gammu не настроена, то можно выбрать один из 2-х способов настройки:
| |
| *Обновить пакет <code>wb-configs</code>. Для этого, нужно выполнить команды <syntaxhighlight lang="bash">apt update && apt install wb-configs</syntaxhighlight>
| |
| | |
| [[File:Gammu-config.png|300px|thumb|right|Настройка gammu вручную (''gammu-config'')]]
| |
| *Настроить gammu вручную:
| |
| #Выполнить команду <syntaxhighlight lang="bash">gammu-config</syntaxhighlight>
| |
| #В параметре <code>Port</code> укажите <code>/dev/ttyXXX</code> — файл модема, соответствующий вашей модели контроллера.
| |
| #В параметре <code>Connection</code> укажите <code>at115200</code>
| |
| | |
| === Примеры команд gammu ===
| |
| Перед использованием утилиты убедитесь, что соединение с интернетом по протоколу ppp завершено (см. раздел [[#Интернет через PPP | Интернет через PPP]])
| |
| | |
| <syntaxhighlight lang="bash">
| |
| $ gammu networkinfo # посмотреть сеть и базовую станцию, к которой вы подключены
| |
| $ gammu geteachsms # вывести все SMS
| |
| $ gammu getussd '#100#' # запросить баланс на МТС в транслите
| |
| $ gammu sendsms TEXT +79154816102 -unicode -text 'Привет' # отправить на номер сообщение с текстом
| |
| </syntaxhighlight>
| |
| | |
| === SMS и USSD на русском ===
| |
| | |
| SMS и USSD на русском в ''gammu'' пока работают не всегда хорошо, поэтому могут пригодиться команды для переключения языка USSD и перекодирования входящих и исходящих SMS в транслит:
| |
| {| class="wikitable"
| |
| !rowspan="2"|Оператор||colspan="2"|USSD||colspan="2"|SMS
| |
| |-
| |
| !транслит||русский||транслит||русский
| |
| |-
| |
| |МТС||*100*6*2#||*100*6*1#||неизвестно||неизвестно
| |
| |-
| |
| |Мегафон||*105*0#||*105*9#||неизвестно||неизвестно
| |
| |-
| |
| |Билайн||*111*6*2#||*111*6*1#||неизвестно||неизвестно
| |
| |-
| |
| |Теле2||*120#||*120*1#||неизвестно||неизвестно
| |
| |}
| |
| | |
| Для надежной отправки SMS на русском надо проверить локаль и установить LC_ALL=ru_RU.utf8
| |
| | |
| === SMS-уведомления ===
| |
| | |
| Отправка sms-уведомлений об изменении состояния какого-либо устройства реализована в ПО Wiren Board с помощью сервиса уведомлений. Также можно отправлять SMS из движка правил wb-rules, вызывая соответствующую функцию. Подробнее в статье «[[Notification_module#Настройка модуля уведомлений| Модуль уведомлений]]».
| |
| | |
| == Интернет через PPP ==
| |
| {{PeerTube
| |
| | link= https://peertube.wirenboard.com/w/oHEYLobzrjkJtNYHnfpstm
| |
| | text= Настройка интернета через PPP с помощью 2G-модема
| |
| }}
| |
| === Быстрый выход в интернет ===
| |
| Настройки быстрого подключения сбрасываются после перезагрузки контроллера. Если вам нужен постоянный доступ к интернету — настройте автоматический запуск подключения.
| |
| | |
| В стандартное ПО контроллера входят настройки подключения для операторов МТС, Мегафон и Билайн по протоколу ppp. Если вы пользуетесь одним из них, то для быстрого подключения к интернету нужно перезапустить модем и подключится с использованием одной из настроек:
| |
| #Перезапустите модем:
| |
| #:<syntaxhighlight lang="bash">
| |
| wb-gsm restart_if_broken
| |
| </syntaxhighlight>
| |
| #Установите соединение, например, для оператора МТС:
| |
| #:<syntaxhighlight lang="bash">
| |
| pon mts
| |
| </syntaxhighlight>
| |
| #:<code>mts</code> можно заменить на <code>megafon</code> или <code>beeline</code> — зависит от вашего оператора связи.
| |
| # Если соединение больше не нужно — вы можете его завершить командой:
| |
| #:<syntaxhighlight lang="bash">
| |
| poff mts
| |
| </syntaxhighlight>
| |
| | |
| Если на контроллере установлен модуль 3G- или 4G-модем, то для увеличения пропускной способности соединения, демону pppd нужно указать другой порт. Для этого в файле <code>/etc/ppp/peers/<ваш_провайдер_связи></code> замените устройство <code>/dev/ttyGSM</code> на (в зависимости от модема) <code>/dev/ttyUSB0</code> или <code>/dev/ttyACM0</code>.
| |
| | |
| Например, изменим порт для провайдера МТС:
| |
| # Откройте файл <code>/etc/ppp/peers/mts</code>
| |
| #:<syntaxhighlight lang="bash">
| |
| nano /etc/ppp/peers/mts
| |
| </syntaxhighlight>
| |
| # Закомментируйте старый порт и добавьте новый:
| |
| #:<syntaxhighlight lang="bash">
| |
| #/dev/ttyGSM
| |
| /dev/ttyUSB0
| |
| </syntaxhighlight>
| |
| #:порт можно использовать /dev/ttyUSB[0..2] в зависимости от количества и настроек сервисов работающих с модемом.
| |
| # {{Wbincludes:Save nano}}
| |
| | |
| Порты <code>/dev/ttyUSB0</code>,<code>/dev/ttyUSB1</code>,<code>/dev/ttyUSB2</code> появляются автоматически после включения модема командой <code>wb-gsm on</code>.
| |
| | |
| === Автоматический запуск подключения ===
| |
| [[Image:Etc-network-interfaces.png|300px|thumb|right|Файл ''/etc/network/interfaces'', автоматически запускающий подключение к МТС]]
| |
| | |
| Чтобы подключение запускалось автоматически:
| |
| #Откройте файл <code>/etc/network/interfaces</code> для редактирования:
| |
| #:<syntaxhighlight lang="bash">
| |
| nano /etc/network/interfaces
| |
| </syntaxhighlight>
| |
| #Раскомментируйте или отредактируйте следующие строки:
| |
| #:<syntaxhighlight lang="bash">
| |
| auto ppp0
| |
| iface ppp0 inet ppp
| |
| provider mts # можно заменить mts на megafon или beeline
| |
| #перезапускаем модем, если он завис
| |
| pre-up wb-gsm restart_if_broken
| |
| #Ждем, пока он загрузится и найдет сеть.
| |
| pre-up sleep 10
| |
| </syntaxhighlight>
| |
| # Сохраните изменения и закройте файл.
| |
| # Теперь запустите интерфейс <code>ppp0</code> командой:
| |
| #:<syntaxhighlight lang="bash">
| |
| ifup ppp0
| |
| </syntaxhighlight>
| |
| #:через 10-15 секунд интерфейс <code>ppp0</code> будет доступен.
| |
| # Настройка завершена, теперь при перезагрузке контроллера подключение к интернету восстановится автоматически.
| |
| | |
| Параметры протокола пакетной передачи данных и номера для соединения для каждого провайдера хранятся в директории <code>/etc/chatscripts</code>. В большинстве случаев ничего менять в этих файлах не придется.
| |
| | |
| Для ppp-интерфейсов существуют директории, исполняемые файлы из которых также запускаются на разных фазах установления соединения. Но, если, например, для ethernet-интерфейсов эти скрипты должны находиться в директориях <code>/etc/network/if-down.d</code>, <code>if-post-down.d</code>, <code>if-pre-up.d</code>, <code>if-up.d</code>, то соответствующие директории для ppp-интерфейсов находятся в <code>/etc/ppp/ip-down.d</code>, <code>ip-up.d</code> и т.п. Подробнее об их назначении и функционировании можно узнать в документе [http://citforum.ru/operating_systems/linux/HOWTO/PPP-HOWTO.shtml PPP HOWTO].
| |
| | |
| === Резервирование канала связи ===
| |
| | |
| Особенности резервирования выхода в интернет описаны в статье [[Wirenboard6:InstallingOnTheRemoteSite#PPP — основной и резервный выход в интернет|Сетевые настройки контроллера]].
| |
| | |
| == Интернет с 4G-модемом (LTE) ==
| |
| {{PeerTube
| |
| | link= https://peertube.wirenboard.com/w/x5bfqydAJVZ5Zz4bKwGCE9
| |
| | text= Настройка модема [[WBC-4G]] на контроллере Wiren Board 6.7.2
| |
| }}
| |
| | |
| [[Image: Minicom-AT-4G.png |500px|thumb|right| Отправка AT-комманд для модема в терминале программы [[minicom]]]]
| |
| [[Image: Minicom-AT-4G-Exit.png |500px|thumb|right| Выход из программы [[minicom]]]]
| |
| === Настройка модема как сетевой карты ===
| |
| В отличие от 2G- и 3G-модулей, [[WBC-4G]] поддерживает выход в интернет через виртуальную сетевую карту по протоколу RNDIS.
| |
| | |
| '''Настройка с помощью minicom''':
| |
| # Убедитесь, что модем правильно сконфигурирован. Подробнее смотрите на странице модуля [[WBC-4G#Конфигурирование | WBC-4G]].
| |
| {{Wbincludes:GSM Modem AT Prepare}}
| |
| # Отправьте из терминала minicom AT-команды для модема:
| |
| #* Настроить автоматическое подключение: <code>AT+DIALMODE=0</code>.
| |
| #* Установить APN: <code>AT+CGDCONT=1,"IP","xxx"</code>, где xxx — точка подключения (APN). Имя точки подключения зависит от оператора, например, у МТС она выглядит так: <code>internet.mts.ru</code>.
| |
| #* Проверить получение IP адреса: <code>AT+CGCONTRDP</code>.
| |
| # Закройте minicom, для этого нажмите на клавиатуре клавиши <kbd>Ctrl</kbd>+<kbd>A</kbd>, затем клавишу <kbd>X</kbd> и подтвердите выход клавишей <kbd>Enter</kbd>.
| |
| | |
| После этого интернет будет доступен через интерфейс <code>usb0</code>, который можно настроить как обычную сетевую карту.
| |
| | |
| '''Настройка с помощью chat''':
| |
| # Убедитесь, что модем правильно сконфигурирован. Подробнее смотрите на странице модуля [[WBC-4G#Конфигурирование | WBC-4G]].
| |
| # Подключитесь к контроллеру по [[SSH]].
| |
| # Перезапустите модем командой:
| |
| #: <syntaxhighlight lang="bash">
| |
| wb-gsm restart_if_broken
| |
| </syntaxhighlight>
| |
| # Замените в строке ниже APN_INTERNET на точку подключения вашего провайдера, вставьте изменённую строку консоль контроллера и нажмите на клавиатуре <kbd>Enter</kbd>:
| |
| #: <syntaxhighlight lang="bash">
| |
| PORT=/dev/ttyGSM; /usr/sbin/chat -s TIMEOUT 20 ABORT "ERROR" ECHO ON "" "AAAAAAAAAAAAAT" OK "AT+CMGF=1" OK "AT+DIALMODE=0" OK "AT+CGDCONT=1,\"IP\",\"APN_INTERNET\"" OK "AT+CGCONTRDP" "OK" > $PORT < $PORT
| |
| </syntaxhighlight>
| |
| | |
| Этот способ можно использовать при написании скриптов.
| |
| | |
| === Настройка виртуальной сетевой карты ===
| |
| ==== Включение ====
| |
| После того как мы настроили модем, нужно настроить виртуальную сетевую карту:
| |
| # Откройте файл <code>/etc/network/interfaces</code>:
| |
| #:<syntaxhighlight lang="bash">
| |
| nano /etc/network/interfaces
| |
| </syntaxhighlight>
| |
| # Добавьте в него строки:
| |
| #:<syntaxhighlight lang="bash">
| |
| auto usb0
| |
| allow-hotplug usb0
| |
| iface usb0 inet dhcp
| |
| pre-up sleep 8
| |
| pre-up wb-gsm restart_if_broken
| |
| pre-up sleep 10
| |
| </syntaxhighlight> | |
| #: автоматически запустить модем, интерфейс и получать IP-адрес. Задержки ''pre-up sleep'' перед и после включения модема нужны для надёжного старта.
| |
| # Сохраните и закройте файл <code>interfaces</code>. {{Wbincludes:Save nano}}
| |
| # Запустите интерфейс командой:
| |
| #:<syntaxhighlight lang="bash">
| |
| ifup usb0
| |
| </syntaxhighlight>
| |
| | |
| Настройка завершена, теперь модем по DHCP назначит контроллеру IP-адрес в подсети <code>192.168.0.1</code>, а после перезагрузки контроллера соединение с интернетом восстановится автоматически.
| |
| | |
| При необходимости можно сменить подсеть модема, чтобы он выдавал контроллеру адрес не из подсети <code>192.168.0.ххх</code>, а, например, <code>192.168.100.ххх</code>. Для этого нужно выполнить AT-команду:
| |
| <syntaxhighlight lang="bash">
| |
| AT+USBNETIP=0,100,111
| |
| </syntaxhighlight>
| |
| Команда имеет следующий синтаксис:
| |
| <syntaxhighlight lang="bash">
| |
| AT+USBNETIP=<mode>,<tpos>,<dhcps>,<dhcpe>
| |
| </syntaxhighlight>
| |
| | |
| {| border="1" class="wikitable" style="text-align:left"
| |
| |-
| |
| |<mode> ||
| |
| 0 – частный IP-адрес (по умолчанию, 192.168.0.xxx и т. д.) </br>
| |
| 1 – Публичный IP (ip из сети). Вступает в силу после перезагрузки модема.
| |
| |-
| |
| |<tpos> || Третья позиция IP-адреса
| |
| |-
| |
| |<dhcps> || Начальное значение DHCP
| |
| |-
| |
| |<dhcpe> || Конечное значение DHCP
| |
| |}
| |
| | |
| '''Предупреждение!''' Данная функция может не работать на модемах со старыми прошивками. Узнать, что модем поддерживает эту функцию можно командой
| |
| <syntaxhighlight lang="bash">
| |
| AT+USBNETIP? | |
| </syntaxhighlight>
| |
| Функция поддерживается, если получен ответ
| |
| <syntaxhighlight lang="bash">
| |
| +USBNETIP: mode
| |
|
| |
|
| OK | | OK |
| </syntaxhighlight> | | </pre> |
| | |
| ==== Отключение ====
| |
| # Остановите интерфейс командой:
| |
| #:<syntaxhighlight lang="bash">
| |
| ifdown usb0
| |
| </syntaxhighlight>
| |
| # Откройте файл <code>/etc/network/interfaces</code>:
| |
| #:<syntaxhighlight lang="bash">
| |
| nano /etc/network/interfaces
| |
| </syntaxhighlight>
| |
| # Закомментируйте или удалите строки:
| |
| #:<syntaxhighlight lang="bash">
| |
| #auto usb0
| |
| #allow-hotplug usb0
| |
| #iface usb0 inet dhcp
| |
| # pre-up sleep 8
| |
| # pre-up wb-gsm restart_if_broken
| |
| # pre-up sleep 10
| |
| </syntaxhighlight>
| |
| # Сохраните и закройте файл <code>interfaces</code>. {{Wbincludes:Save nano}}
| |
| | |
| ==Мультиплексирование==
| |
| | |
| Модем поддерживает режим мультиплексирования — создания виртуальных портов, через которые можно одновременно работать с модемом.
| |
| Например, через один порт можно открыть сессию PPP для GPRS, а через другой — получать и отправлять SMS, проверять баланс и т.д.
| |
| Подробнее смотрите [[Special:MyLanguage/CMUX|CMUX]]. Этот режим не поддерживается для 2G-модемов.
| |
| | |
| ==Документация на модемы==
| |
| | |
| {| class="wikitable"
| |
| !Модель||Режимы сети||краткое описание||hardware design||AT-команды
| |
| |-
| |
| |SIM800||2G||[http://www.mt-system.ru/sites/default/files/documents/sim800_spec_20140423.pdf pdf]||[http://www.mt-system.ru/sites/default/files/documents/sim800_hardware_design_v1.10.pdf pdf]||[http://www.mt-system.ru/sites/default/files/documents/sim800_series_at_command_manual_v1.12.pdf pdf]
| |
| |-
| |
| |SIM5300E||2G/3G||[http://www.mt-system.ru/sites/default/files/documents/sim5300e_spec_v1611_rus_0.pdf pdf]||[http://www.mt-system.ru/sites/default/files/documents/sim5300e_hardware_design_v1.09.pdf pdf]||[http://www.mt-system.ru/sites/default/files/documents/sim5300e_at_command_manual_v1.01.pdf pdf]
| |
| |-
| |
| |SIM7000E||2G/NB-IOT||[http://www.mt-system.ru/sites/default/files/documents/sim7000e_spec_v1706_rus.pdf pdf]||[http://www.mt-system.ru/sites/default/files/documents/sim7000_hardware_design_v1.07.pdf pdf]||[http://www.mt-system.ru/sites/default/files/documents/sim7000_series_at_command_manual_v1.06.pdf pdf]
| |
| |-
| |
| |7600E||2G/3G/4G
| |
| |colspan="3"| [[WBC-4G#Документация|WBC-4G]]
| |
| |}
| |
|
| |
|
| == GPRS на модемах SIM7000E 2G/NB-IoT == | | ===Мультиплексирование=== |
| | Модем поддерживает режим мультиплексирования - создание виртуальных портов, через которые можно одновременно работать с модемом. |
| | Например через один порт можно открыть сессию PPP для GPRS, а через другой получать и отправлять SMS, проверять баланс и т.д. |
| | Подробнее смотрите [[CMUX]]. |
|
| |
|
| Модем SIM7000E 2G/NB-IoT по умолчанию настроен на автоматический выбор GSM- и LTE-сетей. Однако, в сети или с SIM-картой без поддержки NB-IoT модем не регистрируется в сети GSM (GPRS).
| | ===Работа с GPRS=== |
| Для того, чтобы модем смог зарегистрироваться в сети GSM, необходимо принудительно перевести его в режим GSM only.
| | [[Настройка GPRS в Debian]] |
|
| |
|
| В терминальном режиме работы с модемом, например, в программе minicom (смотрите раздел [[GSM/GPRS#Отправка AT-команд|Отправка AT-команд]]), введите команду выбора режима:
| |
| <syntaxhighlight lang="bash">
| |
| AT+CNMP=13
| |
| </syntaxhighlight>
| |
|
| |
|
| Возможные варианты значений (команда <code>AT+CNMP=?</code>):
| | ===RTC=== |
| *<code>2</code> — Automatic,
| |
| *<code>13</code> — GSM Only,
| |
| *<code>38</code> — LTE Only,
| |
| *<code>51</code> — GSM And LTE Only.
| |
|
| |
|
| Установить режим нужно один раз — он запоминается и активен даже после отключения питания.
| |
|
| |
|
| Чтобы вернуться в режим IoT, выполните команду:
| | ===Настройки мощности по-умолчанию=== |
| <syntaxhighlight lang="bash"> | | <pre> |
| AT+CNMP=51 | | AT+CRTXVMA? |
| </syntaxhighlight> | | +CRTXVMA: (0204,01C9,0184,0149,0118,00EF,00CE,00B3,009E,008E,0081,0077,006F,0067,005F,0053),(021A,01B6 |
| | ,016D,0131,0105,00E0,00C4,00AE,009B,008C,0080,0078,0071,006A,0065,0053),(023A,01B7,0181,014F,0122,00FC |
| | ,00DC,00C1,00AB,009A,008B,007F,0076,0072,006B,0068),(01F4,01AF,0165,012A,00FB,00D7,00BB,00A5,0093,0086 |
| | ,007A,0071,006B,0065,0061,005D) |
| | </pre> |
В Wiren Board установлен GSM/GPRS-модуль SIM900R, с помощью которого можно:
- отправлять СМС
- принимать СМС
- устанавливать соединение с интернетом
Полный список возможностей смотрите в описании модуля.
Работа из Linux
Внутри контроллера модем подключён к процессору по двухпроводному последовательному порту (UART). В Linux этот порт отображается как псевдоустройство /dev/ttyAPP0 (первый порт (Application UART) процессора). Модуль управляется посредством передачи команд на этот порт.
Кроме того, модуль можно выключить и перезагрузить, подав сигналы на контакты модуля PWRKEY и RESET. Для этих целей написана простая утилита wb-gsm (примеры использования смотрите ниже). Прямой доступ к этим контактам реализован через GPIO (подробнее читайте GPIO, ищите в таблице соответствующие названия).
Включение модуля
Для включения или перезагрузки модуля можно пользоваться утилитой wb-gsm из репозитория https://github.com/contactless/wirenboard .
Примеры:
$ wb-gsm on # включение устройства
$ wb-gsm off # выключение устройства
$ wb-gsm reset # перезагрузка включенного устройства
Работа с модулем
Ознакомьтесь с инструкцией Работа с последовательным портом из Linux
Для интерактивного режима:
- запускаем minicom с ключём, создающим профиль работы с портом (скорость передачи данных, чётность, и т.д.):
$ minicom -s /dev/ttyAPP0
- Зайти в настройки (нажать Ctrl+A, затем O), выбрать пункт Serial port setup, там установить порт /dev/ttyAPP0, скорость и чётность - 115200, 8N1, Hardware flow control - No, Software flow control - No
- Сохранить настройки: Save setup as _dev_ttyAPP0
- Далее запускать как minicom /dev/ttyAPP0 (все параметры будут сразу браться из профиля с названием /dev/ttyAPP0, который мы ранее создали)
- Первой вашей командой должна стать AAAAAAAAAT - с её помощью модуль распознает скорость, с которой мы к нему обращаемся (смотрите SIM900R)
- Второй командой выполните просто AT. Вам должен прийти ответ OK
Примеры команд
- Синхронизовать скорость порта (не совсем команда)
AAAAAAAAAAAAAT
AT+COPS=?
AT+CSQ
- Звонок на номер +79154816100
ATD+79154816100;
- Установка baud rate порта в фиксированное значение 115200
AT+IPR=115200
- Запрос времени со встроенных в модуль часов реального времени (RTC)
AT+CCLK?
AT+CCLK="14/03/19,01:20:29+00"
- Получить IMEI-код модуля (xxxxxx - уникальный номер)
AT+GSN
86820400xxxxxxY
OK
Мультиплексирование
Модем поддерживает режим мультиплексирования - создание виртуальных портов, через которые можно одновременно работать с модемом.
Например через один порт можно открыть сессию PPP для GPRS, а через другой получать и отправлять SMS, проверять баланс и т.д.
Подробнее смотрите CMUX.
Работа с GPRS
Настройка GPRS в Debian
RTC
Настройки мощности по-умолчанию
AT+CRTXVMA?
+CRTXVMA: (0204,01C9,0184,0149,0118,00EF,00CE,00B3,009E,008E,0081,0077,006F,0067,005F,0053),(021A,01B6
,016D,0131,0105,00E0,00C4,00AE,009B,008C,0080,0078,0071,006A,0065,0053),(023A,01B7,0181,014F,0122,00FC
,00DC,00C1,00AB,009A,008B,007F,0076,0072,006B,0068),(01F4,01AF,0165,012A,00FB,00D7,00BB,00A5,0093,0086
,007A,0071,006B,0065,0061,005D)