Как установить драйвера rndis
Добавлю, что после установки сетевого IP-адреса модуль ЦП SlimLine он будет доступен через TCP / IP, как любой модуль, подключенный к сети. Например, введя адрес модуля в адресную строку браузера (Пример 192.168.1.122), мы можем отобразить веб-страницу конфигурации (Скриншот).
Таким же образом мы сможем получить к нему доступ из LogicLab с подключением ModbusTCP на порт 502, с Telnet на порт 23 и с FTP на порт 21. Путем доступа в Ftp с помощью проводника ресурсов Windows (определение в адресной строке ftp: // Admin:[электронная почта защищена]), мы сможем увидеть файловую систему модуля CPU (Скриншот).
Добавлю, что все, что описано относительно драйвера RNDIS, также доступно на Модули CPU ARM7 версия B, начиная с кода операционной системы SFW184A200.
Я заявляю, что это первый раз, когда я использую эти ПЛК, я загрузил LogicLab, я создал программу, я подключил USB-кабель, но система не распознает, он сообщает мне, что сеть не распознается, мои попытки восстановить драйверы в сети были неудачными. Как я могу сделать ?.
Не сообщайте мне, какой модуль ЦП вы используете, драйвер USB RNDIS недоступен в версиях ЦП ARM7 версии A. Если ваш модуль управляется и вы используете Windows XP, 7 или 8, как упоминалось ранее, драйвер для поиска отсутствует, поскольку он является родным для Система Windows.После установки сетевой карты RNDIS необходимо назначить ей IP-адрес, принадлежащий той же сети, что и ЦП. SlimLine (По умолчанию 192.168.1.122), следуйте инструкциям в предыдущем посте.
Я купил свой первый комплект SlimLine состоящий из MPS050A010 и PCB124B000, я использовал собственный ноутбук Toshiba XP, после тысячи попыток установить связь с помощью предоставленного вами USB-кабеля я построил кабель RS232, с Tolly он работает, но я не смог взаимодействовать с программой LogicLab.
В отчаянии из-за сроков доставки я использовал ноутбук с W7 и… соединение отлично работает как с браузером, так и с LogicLab. К сожалению, этот компьютер взят в аренду, я хотел задать вам два вопроса:
1. Вы уверены в совместимости драйвера RNDIS на XP или в том, что никаких других специальных обновлений не требуется?
2. Желая использовать соединение RS232 с LogicLab, что является процедурой, я не смог найти его на форуме,
Ps. Я считаю, что терминалы ввода / вывода немного малы. Поздравляем с простой и понятной платформой LogicLab.
Мы внедрили несколько установок драйвера RNDIS в системах Windows XP без особых проблем, конечно, системы XP обновлены до пакета обновления III.
Доброе утро, у меня тоже были нерешенные проблемы со связью между SlimLine и мобильные ПК с пакетом обновления 3.
-1 Compaq 2003 mobile все плавное.
-Portable 2 Dell 64bit с XP подключается, но не может быть доступен ни через Интернет, ни с LogicLab.
- Исправлена проблема с HP в компании с такой же проблемой, как ноутбук 2.
Я заявляю, что в ноутбуке №2 в отчаянии я удалил антивирус и отключил брандмауэр, но ничего, я сделал тысячу проверок, чтобы настройки ноутбука 2 были идентичны настройкам ноутбука 1, но делать нечего.
Во всех трех я установил драйвер, содержащийся в папке RndisSetup.
Привет, у меня есть MPS046A100, и я очень старался найти этот пост на сайте. Так как у меня одна из первых версий SlimLine глядя на документацию Slimline новее я нашел только ссылки на возможность подключения через USB, который моя версия не поддерживает, будучи A.
Я спрашиваю, есть ли обновление прошивки для A, поскольку моя монтирует SFW167C000 и какую производительность она добавляет. Я также предлагаю сделать специальный раздел для старых процессоров, так как название такое же.
Модуль CPU MPS46A100 оснащен портом Ethernet, и Ethernet-соединение, безусловно, является наилучшим возможным подключением. Помните, что вы можете подключаться к модулю CPU также через последовательный порт в RS232 и RS485.
Управление протоколом TCP / IP на USB является очень тяжелым для ЦП по сравнению с тем же управлением через порт Ethernet, и поэтому мы всегда рекомендуем, если он доступен, использовать порт Ethernet. Помимо изменений программного обеспечения, поддержка USB также привела к изменениям оборудования, поэтому невозможно обновить модули ЦП модели A новыми версиями программного обеспечения.
Я тоже собираюсь броситься в мир Elsist и у меня до сих пор много неразберихи в голове. Просматривая форум, я попал в эту очень интересную ветку. Для приложения, которое я должен разработать, меня интересуют модели MPS050 * 010 или MPS050 * 320.
Быстрый вопрос, как поддержка RNDIS ведет себя на ваших 10-битных процессорах Windows 64? Возможна ли связь с ЦП в MODBUS-TCP через соединение RNDIS?
Драйвер RNDIS полностью совместим с Windows 10 и уже встроен в операционную систему. Вот скриншот использования в Windows 10, поскольку вы можете видеть, что он рассматривается как сетевая карта. В свойствах карты необходимо указать сетевой адрес, по умолчанию SlimLine на RNDIS он имеет адрес 192.168.1.122, поэтому адрес карты будет определен в том же классе. Attenzione a verificare che nel tuo PC non vi siano già altre schede che utilizzano la stessa classe di rete.
С момента установки Windows 10 я впервые пытался подключиться к одному SlimLine без порта Ethernet (с использованием порта USB). Windows сообщает мне, что не может найти драйверы, что мне делать?
Как уже было сказано в предыдущем посте, драйвер RNDIS изначально присутствует в Windows 10, когда вы его подключаете. SlimLine установка начнется автоматически на ПК (Скриншот).
После завершения установки драйвера с помощью значка сети (на панели Windows) можно получить доступ к панели свойств соединения RNDIS и установить IP-адрес, который будет назначен карте (Скриншот).
При установке IP-адреса карты RNDIS, адрес должен быть определен в том же классе сети, что и SlimLine (192.168.1.xxx) вы можете определить, например, 192.168.1.10 (Скриншот). Внимание: сначала убедитесь, что ни одна из сетевых карт или соединение с WiFi в ПК не находятся в одном классе.
С внесением нового законодательства по онлайн кассам фискальные регистраторы и кассовые аппараты обязаны передавать фискальные данные в ОФД через сеть Интернет. В большинстве случаев сделать это можно посредством порта Ethernet или беспроводной связи Wi-Fi или мобильной сети GSM. Однако, существует оборудование, которое способно передавать данные посредством USB порта (благодаря протоколу RNDIS). И некоторые бюджетные аппараты Штрих-М осуществляют передачу данных только таким образом, например ККМ Штрих-Онлайн или Ритейл-01Ф.
К сожалению, в отличие от оборудования АТОЛ, в котором для подобной операции используется служба Ethernet over USB, оборудование Штрих-М настраивается очень неудобно. Процесс потребует знаний в области настройки домашней сети и опыта работы с таблицами в драйверах Штрих-М. В этой статье мы подробно распишем последовательность настройки, возможные сложности и решение возникающих проблем.
Мнение пользователя: лучше не приобретать ККТ Штрих-М с передачей данных через USB, ни на одном из компьютеров настроить передачу фискальных данных не удалось.
Для корректной работы Вам могут потребоваться драйвер RNDIS и драйвер VCOM.
ВНИМАНИЕ:
Для работы по протоколу RNDIS Штрих-Онлайн ККТ обязательно должен быть прошит прошивкой С.1, сборка 35433, дата сборки 14.02.2017. С более старой прошивкой нет даже смысла пытаться настроить ККТ (мало того, что система не заработает, так еще и придется делать технологическое обнуление устройства).Установка драйвера ККМ Штрих-М
Установка драйвера - самый простой из описанных в этой статье процессов. Скачиваете архив, распаковываете и запускаете установщик. Далее просто следуйте инструкциям в окне установщика.
Подключение ККТ к ПК и основные настройки
После установки Тест драйвера ФР и подключению ККТ к компьютеру через USB, требуется запустить драйвер.
- Далее выбрать Настройка свойств
- В открывшемся окне выбрать Поиск оборудования.
- Далее нажать кнопку Начать
- Дождаться окончания поиска оборудования и нажать ОК
Если во время поиска ни одно устройство не было найдено - проверьте соединение ККТ и ПК.
После того, как проверка соединения пройдена требуется зайти в сетевые настройки устройства. Делается это таким образом:
- В Настройках свойств ККТ нажать кнопку Таблицы.
- В таблицах найти строчку 21 - Сетевые интерфейсы.
- Нажать клавишу Открыть.
- Откроется окно редактирования параметров сети.
В этом окне в самом последнем поле (9) будет указано значение Rndis - 0. Требуется поменять значение на 1 и нажать Enter, таким образом мы активируем возможность передачи фискальных данных в ККТ через USB.
Вы можете заметить строчки с 5 по 8 в которых указаны параметры беспроводной сети Wi-Fi. Если Ваш аппарат не "вооружен" подобным беспроводным модулем, то какие бы Вы настройки в строчки не вводили - толку будет ноль. Наличие модуля беспроводной связи смотрите в документации, поставляемой с устройством.
Однако, если в строчке "Наличие Wi-Fi" будет указано значение 1, то Вам крупно повезло - Ваш аппарат может подключаться к сети через беспроводное подключение. Таким образом следующая мозгодробящая инструкция Вам не потребуется.
Если все настроилось хорошо, то в Сетевых подключениях Windows должно отобразиться сетевое подключение RNDIS в тот момент, когда ККМ Штрих-М подключена к компьютеру через USB.
В свойствах подключения открываем свойства IP версии 4. Установим "Использовать следующий IP-адрес" и укажем адрес подобный такому: 192.168.137.111 и маску подсети 255.255.255.0.
Далее переходим к настройкам сети в зависимости от динамического или статического IP-адреса в Вашей сети.
Если в сети используется статический адрес, то в графе Static ip ставим 1, иначе ставим 0.
В любом случае вводим параметры, как на скриншоте снизу.
Ну и в принципе все. Сохраняем введенные параметры и. молимся всем известным богам, что бы все это заработало.
Дело в том, что на моем личном компьютере все это не заработало ни в какую, при этом на компьютере клиента все заработало.
Возможные проблемы
К сожалению, у Штрих-М к передаче данных через USB наплевательский подход. Система может не заработать в принципе. Либо работать через раз.
Обязательно, должна быть прошивка не ниже С.1, сборка 35433, дата сборки 14.02.2017. Без этой прошивки, по заявлениям разработчика ничего не будет работать (что далеко не факт).
Возможны проблемы с синхронизацией 1С и настроенного как сетевое устройство ККТ.
Вы запускаете изображение на базе Windows Embedded CE 6,0, в котором включена SYSGEN_ETH_USB_HOST переменная на устройстве CE.
Устройство CE поддерживает адаптеры Ethernet, совместимые с интерфейсом сетевых драйверов (RNDIS).
Вы подключаете USB-устройство RNDIS, например Windows Phone, к устройству CE.
В этом сценарии устройство CE не распознает устройство RNDIS.
Причина
Эта проблема возникает из-за того, что функция USBDeviceAttach в драйвере RNDIS (Usb8023. dll) не проверяет класс ActiveSync в дескрипторе USB. Драйвер RNDIS загружает и затем выгружается сразу во время подключения.
Решение
Сведения об обновлении программного обеспечения
Корпорация Майкрософт выигрывает поддерживаемое обновление программного обеспечения в виде ежемесячного обновления для Windows Embedded 6,0, выпущенного в формате Июнь 2011. В разделе "сведения о файлах" имя файла пакета содержит версию продукта, дату, номер статьи базы знаний и тип процессора. Формат имени файла пакета выглядит следующим образом:
Центр загрузки Майкрософт
Предварительные условия
Это обновление поддерживается, только если установлены все ранее выпущенные обновления для этого продукта.
Требование перезагрузки
После применения этого обновления необходимо выполнить чистую сборку всей платформы. Это можно сделать одним из описанных ниже способов.
В меню Сборка выберите Очистить решениеи нажмите кнопку построить решение.
В меню Сборка выберите команду Перестроить решение.
После установки этого обновления программного обеспечения вам не нужно перезагружать компьютер.
Сведения о замене обновлений
Это обновление не заменяет никакие другие обновления.
Сведения о файлах
Английская версия этого пакета обновления программного обеспечения содержит атрибуты файлов (или более поздние версии), указанные в приведенной ниже таблице. Дата и время для файлов указаны в формате UTC. При просмотре сведений о файлах выполняется перевод соответствующих значений в местное время. Чтобы узнать разницу между временем UTC и местным временем, откройте вкладку Часовой пояс элемента Дата и время панели управления.
Первым делом хотелось бы с лучшими пожеланиями поздравить всех с минувшими новогодними праздниками.
Ранее в статье была анонсирована разработка RNDIS USB драйвера для контроллеров серии STM32F4. С тех пор библиотека постепенно развивалась и нынче доросла до первой release-версии. Библиотека под названием LRNDIS (LWIP + RNDIS) позволяет нам создавать на базе контроллера STM32F4 как устройства класса USB «модем», так и любые другие устройства с управлением через web-интерфейс. Пример управления платой stm32f4-discovery из web-браузера на Android-планшете представлен на видео:
На странице видеоролика представлена ссылка на исходные коды и HEX-файл прошивки для платы discovery, с которым вы сможете повторить данный эксперимент. В статье рассказано о том, как и когда технология доступа через WEB-интерфейс полезна, а также — как работает библиотека LRNDIS для контроллеров STM32F4. Также присутствует обучающий материал о работе USB и устройстве Ethernet-сетей.
Предыстория создания библиотеки
Предыстория проекта весьма типовая. Стоял тёплый летний день. Гхм… Для заказчика стояла задача разработать устройство с сервисным интерфейсом управления.
По мере развития прошивки было введено несколько команд управления по VCP-интерфейсу. Это значит, что после подключения USB-устройства в ОС создавался виртуальный COM-порт. Используя его, из пользовательского терминала передавались команды управления и диагностики. В ответ от устройства принимался статус выполнения и его текущее состояние.
Система вполне типовая с сервисной точки зрения: есть последовательный порт и набор команд для управления и диагностики.
Всё изменилось в короткий срок. По объективным причинам рос требуемый набор команд. Также понадобилась интерактивность вывода: некоторые параметры стало необходимо отображать в динамике. Как, например, показания магнитного датчика при проносе мимо него ферромагнетика. Для этого были введены дополнительные команды, которые, оперируя управляющими последовательностями, печатали информацию в пользовательском терминале с высокой периодичностью. Это создавало необходимое ощущение риалтаймовости наблюдения. Интерактивные команды оказались настолько удобными для инженеров, что некоторая часть команд позже была добавлена в соответствии с концепцией. И тут раздался треск. Требовалось поддержать сразу несколько групп команд: интерактивные, диагностические, команды управления. При этом периодический рефакторинг кода был связан с трудоёмкой правкой в большом количестве обрабатываемых команд. Ясно стало, что ещё должна быть пользовательская группа команд — для менее квалифицированного персонала, который будет просто следовать инструкциям по эксплуатации. Для них возникла идея написания клиентского терминала с кнопочками и флажочками… И вот тут возникли сомнения: стало ясно, что мы занимаемся сервисной частью, уделяя всё меньше внимания функциональности! А ведь пользовательская программа, запускаемая на клиентской ЭВМ, также должна обладать своими требованиями: кроссплатформенность и LTS (длительностью поддержки).
Устройство, предположим, мы закончили, а пользовательское ПО мы должны портировать и тестировать с каждой версией выпускаемых операционных систем! А как долго?
Так и родился вопрос — как избавиться от дополнительных трудозатрат?
Было принято решение использовать стандарты гарантированно длительной поддержки. Те стандарты, которые нам позволят создать клиентскую программу управления устройством, которая будет поддерживаться максимально полным набором операционных систем в настоящем и будущем времени. На первых парах были найдены недостатки популярных кроссплатформенных фрэймворков:
— java: необходимость наличия в ОС JVM, и вытекающий из противного предположения необходимость дистрибьюции виртуальной машины
— qt: периодическая необходимость версионного портирования и нюансы запуска под Android.
Нет, эти сложности пугать не должны. Вопрос, пожалуй, только в трудочасах, которые мы, бывает, недооцениваем с учётом фактора длительной поддержки.
Сфера применения библиотеки
К сожалению, первый анонс в полной мере успешным не был, т.к. рассказ о сфере применения был упущен.
Попробуем немного наверстать упущенное и раскрыть эту тему.
Если мы находимся на этапе системного проектирования устройства, то следующие соображения могут склонить нас в сторону использования web-интерфейсов (вне зависимости от физического канала, Ethernet или USB):
1. Устройство должно иметь интерфейс управления и/или диагностики
2. Средства управления могут использоваться не только на этапе разработки, но и на этапе эксплуатации (ПО пользователя)
3. Квалификация пользователя может быть недостаточно высокой, что требует дружественный интерфейс управления
4. Способ «дружественного» управления должен быть доступен из под разных платформ и ОС
5. Соответствующие средства требуется поддерживать в рабочем состоянии длительное время
Дополнительным критерием может являться то, разрабатываем ли мы изначально сетевое устройство. А также: не будет ли (в противном случае) добавление в прошивку сетевого стека и web-сервера являться избыточным на фоне куда менее богатого функционала устройства. Иными словами, добавление web-интерфейса в контроллер управления лампочкой — очевидно, избыточное решение.
Если мы поверили в web-интерфейс, то следующие соображения, возможно, нам помогут в выборе физического канала связи (из Ethernet и USB перспективы).
Тип | Внутрисхемное подключение | Типовое применение |
Ethernet | Ethernet PHY контроллер | — Промышленные устройства — Бытовые устройства с сетевой функцией и доп. питанием |
USB | ULPI контроллер или прямое подключение к МК | Бытовые и часть промышленных устройств. В особенности, если: — устройства имеют не гарантированный источник питания (питание от батареи, например) — устройства потенциально подключаемые к хосту только с USB интерфейсом (например, планшет) — миниатюрный класс устройств |
От себя добавлю — не смотря на все прелести, не посоветовал бы применять USB в промышленных узлах с требованием повышенной надёжности: часто встречается негативный опыт. Если альтернативы нет — то вопрос устойчивости требуется изучить досконально.
Исходя из приведённых пунктов, становится ясна сфера применения библиотеки: бытовые и часть промышленных устройств, которые:
— работают на базе МК STM32F4
— должны обладать дружественным интерфейсом управления
— должны управляться из под разного аппаратного и программного набора
— могут не иметь гарантированного источника питания
— должны иметь длительный период поддержки ПО управления
Возможных примеров использования технологии много даже вне области сугубо сетевых устройств.
К примеру, на данный момент есть планы по превращению stm32f4-discovery в инструмент любительской разработки с функциями портативного генератора/анализатора сигналов и осциллографа. Подключите такой помощник к телефону и посмотрите в динамике что происходит в интересующей вас цепи. Из бесплатных плюсов — не требуется собирать или устанавливать ПО; достаточно прошить HEX-файл и открыть браузер — в нём будут присутствовать все прелести GUI-интерфейса. На мой привередливый вкус — то что нужно. Конечно, инструмент не для профессиональной разработки, но известный интерес к нему присутствует.
Итак, надеюсь, разобрались. А теперь о том как работает библиотека.
Как оно работает
При ответе на этот вопрос спешить не будем. Человек, имеющий небольшой опыт взаимодействия с сетями, может вполне справедливо смутиться. Поэтому, касаясь того или иного протокола взаимодействия я буду также давать его краткое техническое описание на том уровне… которого когда-то не хватало самому.
Шаг 1. Подключаем USB-устройство.
Как говорилось раньше, на этом этапе наше устройство говорит хосту «я — сетевая карта!».
Хост (т.е. клиентская ЭВМ) после подключения к нему нашей поделки, начинает отправлять запросы.
— как изделие называется
— какой у изделия VID и PID (идентификаторы производителя и изделия, см. список)
— к какому классу и подклассу относится устройство
— по каким endpoint точкам и какими блоками следует обмениваться данными
Ну, и некоторую другую информацию. Конфигурационные пакеты при этом передаются по точке endpoint 0. Ответные пакеты от устройства с информацией о себе обычно называют «дескрипторы USB устройства».
Подробно ознакомиться о процессе опроса (энумерации) можно здесь.
Вообще, протокол USB достаточно богат… иногда даже кажется, что избыточно. Однако, это богатство вот уже много лет позволяет подключать совершенно разные устройства, даёт возможность передавать изохронные потоки, блоки данных, прерывания. В общем, всё необходимое, что может потребоваться широкому набору современных устройств. Обратная сторона медали — высокий порог входа в разработку USB-устройств.
После получения информации об устройстве, ОС хоста производит поиск подходящего драйвера для взаимодействия. В типовом случае, вроде flash-носителей (USB класс MSC) или клавиатуры с мышкой (HID класс), загружается стандартный для класса драйвер. В более «тяжёлом» случае, вроде нашей USB сетевой карты (CDC класс с RNDIS подклассом), операционная система поступает по усмотрению:
— ОС linux/android/mac, как правило, успешно пытается наладить типовой обмен
— ОС windows просит установить внешний драйвер
Наше устройство в первом случае работает сразу.
В случае ОС windows (позднее XP) можно установить стандартный драйвер фирмы Microsoft. Для Windows XP необходимо поставить inf-файл, доступный в репозитории библиотеки LRNDIS.
Шаг 2. Драйвер инициализирует RNDIS-устройство
На данной картинке изображён принцип связи с RNDIS устройством (ОС Windows).
Более подробно о нём можно почитать тут и там.
Если вкратце, то RNDIS протокол — это расширение NDIS для внешних устройств. Роль протокола — обеспечить поддержку PnP и обмен сетевыми пакетами. По сути своей, RNDIS — самостоятельный сетевой интерфейс, информационной нагрузкой которого являются кадры канального/сетевого уровней (Ethernet или IP кадры, опционально).
На приведённой схеме это реализует кубик «Минипорт Remote NDIS», который отвечает за:
— сервис общения (спросить у сетевого устройства его MAC-адрес, размер пакета, скорость работы и прочее)
— оборачивает отправляемые хостом сетевые пакеты в RNDIS заголовок
— транслирует принимаемые от устройства пакеты, выбрасывая RNDIS заголовок
Кубик «Минипорт Remote NDIS USB» отвечает за транзит RNDIS посылок, работая с драйвером USB шины.
На стороне контроллера STM32 за поддержку RNDIS протокола и работу с USB отвечает файл usbd_rndis_core.c. Он делает то же самое, что и «кубик» хоста «Минипорт Remote NDIS» — занимается приклеиванием/отклеиванием заголовков, а также отвечает на вопросы драйвера. Ответы, вроде MAC-адреса и скорости он берёт из файла usbd_rndis_core.h.
После успешной инициализации RNDIS драйвер Windows создаёт сетевой интерфейс, который в последствии отображается в «Центре управления сетями» и в области трей-индикатора.
Шаг 3. Получение IP-адреса
Итак, для чего нужна служба получения динамического адреса. Эта служба называется DHCP (протокол динамической настройки узла).
После того как хост инициализирует наше устройство, он создаёт сетевой интерфейс.
Сетевой интерфейс — это программная сущность, предоставляющая доступ к ресурсам физической или виртуальной сети.
Чаще всего каждому сетевому интерфейсу хоста соответствует конкретный сетевой адаптер. Но есть множество других интерфейсов, вроде локальной петли или те, что служат для взаимодействия с виртуальной машиной. В их случае в сигнальном виде из хоста «ничего не выходит» — обмен происходит программным способом.
Каждому сетевому интерфейсу хоста должен быть сопоставлен хотябы один IP-адрес. По нему «жители сети» может обратиться к хосту.
Если «на проводе» адресовано несколько сетей (например, устройства с IP адресами 10.4.1.xx и 192.168.1.xx), то интерфейсу может назначаться два «личных» IP-адреса. Они могут выглядеть так: 10.4.1.151 и 192.168.1.200. Узнать набор сетевых интерфейсов и сопоставленных им IP-адресов в ОС Windows можно с помощью команды ipconfig и с помощью ifconfig в ОС Linux.
Для описания сетей/подсетей используется маска. Например, правильное описание сети 10.4.1.xx такое: сеть 10.4.1.0, маска 255.255.255.0. Либо, если 4-ёх байтовое число маски представить в двоичном виде и посчитать число ведущих едениц, то получится значение 24. Тогда сеть можно описать так: 10.4.1.0/24.
Подробнее об этом можно почитать в соответствующих источниках.
Известны две основные стратегии назначения IP-адреса интерфейсу: статический способ (когда пользователь сам прописывает адрес интерфейсу) и динамический (с помощью DHCP-службы).
Последний заключается в том, что при создании интерфейса на хосте активизируется служба DHCP-клиента. Она начинает посылать в сеть (конфигурация которой пока не известна) широковещательные пакеты по протоколу UDP, в надежде на то, что в сети присутствует DHCP-сервер.
Функция DHCP-сервера в общем, и в частности на нашем контроллере — ответить клиенту. В ответе контроллер «говорит»: клиент, ты в такой-то сети, держи такой-то IP-адрес, а ещё у нас имеется DNS-сервер с таким-то адресом.
После этого хост «чувствует себя» намного лучше: он назначает интерфейсу выданный IP-адрес и запоминает IP-адрес DNS-сервера.
Инициализация закончилась, теперь можно вводить имя страницы (run.stm) в браузере хоста.
Надо сказать, что поведение библиотеки LRNDIS настраивается. Службу DHCP-сервера можно исключить из сборки. Тогда на хосте придётся прописывать любой адрес, принадлежащий диапазону 192.168.7.(2-254). Такая сеть создаётся по умолчанию. Её параметры (192.168.7.0/24) также настраиваются. В примере клиенту выдаются адреса в диапазоне 192.168.7.2… 192.168.7.4 с временем лизинга 24 часа.
Более подробно по вопросу настройки библиотеки можно посмотреть в предыдущей статье.
Шаг 4. Загрузка страницы
Для загрузки страницы пользователь может ввести адрес нашего устройства 192.168.7.1 напрямую.
Однако, запоминать цифры не требуется, т.к. помимо DHCP-сервера, есть возможность собрать библиотеку с поддержкой DNS-сервера, функция которого — разрешать сетевые имена. В публикуемом примере DNS-сервер обучен разрешать имя ресурса «run.stm».
Запрос и ответ между браузером Firefox и контроллером:
История запросов при загрузке страницы:
Из истории мы видим, что, после загрузки корневого HTML-документа браузер также загружает из контроллера другие два файла: discovery.svg и zepto.min.js. Первый — это изображение платы discovery. SVG формат выбран, т.к., являясь изображением векторной графики, мало занимает места в ПЗУ микроконтроллера. Скриптовый файл zepto.min.js включён, т.к. является урезанным аналогом знаменитого JQUERY. Надо заметить, что скрупулёзной экономии места в ПЗУ не производилось, т.к. не смотря на жертву в 35 Кб на все статические ресурсы, памяти контроллера ещё вполне достаточно. К тому же данный размер с дальнейшим увеличением сложности интерфейса обещает расти заметно медленней. Если же интерфейс разросся существенно — всегда есть выход хранить и отдавать статические ресурсы в сжатом виде — все известные браузеры на данный момент поддерживают декомпрессию «на лету».
Ещё один запрос, который отправляет браузер — это запрос /state.cgi. Он формируется скриптом из корневого HTML-документа с периодичностью 5 раз в секунду. Нужен запрос для получения в динамике текущего состояния устройства.
При приёме данного запроса, контроллер формирует и отвечает следующей строкой в JSON формате:
Она и содержит все данные о текущем состоянии устройства, которые впоследствии отображаются на странице средствами JavaScript кода.
Ну и, пожалуй, последний момент в общении с браузером — способ управления.
О стеке LWIP
Никакого сетевого обмена устроить бы не получилось, если бы не данный сетевой стек, который и был встроен в библиотеку.
Поскольку библиотека работает под «голым» железом (без ОС и динамической аллокации памяти), то надстройка в виде сокетов для использования недоступна. Написание сетевых приложений поэтому происходит с использованием сырого API стека. По этой теме, к счастью, в сети много информации.
В прошлой статье я давал краткое описание стека и его настройки. На данный момент был уточнён набор важных для стека определений в файле:
Также была решена проблема с mem_malloc. Хоть текущая версия прошивки и не использует динамическую аллокацию, аппаратный крах при вызове mem_malloc держал настороже. Разрешилось добавлением определения MEM_ALIGNMENT, который раньше был обойдён вниманием.
Нерешённые вопросы
1. Ньюансы релицензирования стека lwip, который может иметь свои условия включения в состав другого ПО;
2. Доработка DNS-сервера для обработки «многовопросных» пакетов;
Вместо заключения
Благодарю читателя за терпение и надеюсь, что данная статья окажется для него полезной. Опубликованная в исходных кодах библиотека LRNDIS доступна для использования на правах MIT-лицензии. Считаю замечательным, если работа, на которую было уделено ощутимое время и запас сил, окажется полезной ещё кому-то. На худой конец, без использования открытых библиотек не получилось бы и этой.
Читайте также: