Мини-экран для Умного Дома Яндекс (УДЯ) – продолжение

от автора

Теперь без программирования и необходимости подключения по кабелю!

Можно скачать готовую прошивку, обновиться на нее через web-интерфейс оригинальной прошивки, а потом все настроить – тоже через web-интерфейс. При необходимости, можно вернуться назад.

А можно и с программированием — исходный код по прежнему выложен на Git.

На фото слева направо: GeekMagic SmallTV Pro, SmallTV Ultra, GiftTV Crystal Cube  и NEIMZ мини (NZ1237) – клон SmallTV Ultra, который я купил за 329 рублей.

На фото слева направо: GeekMagic SmallTV Pro, SmallTV Ultra, GiftTV Crystal Cube  и NEIMZ мини (NZ1237) – клон SmallTV Ultra, который я купил за 329 рублей.

Первая часть: Как сделать мини-экран для Умного Дома Яндекс (УДЯ) за 659 рублей?


Содержание:

  1. Введение и благодарности

  2. Основные изменения от версии, описанной в предыдущей статье

  3. Первоначальная настройка и использование YaMon

  4. Процедура миграции на YaMon и возврата назад

  5. Исходный код, нюансы, сложности и трудные решения

  6. Используемое у меня оборудование

  7. Эпилог: планы на будущее


Введение и благодарности

Как я уже написал выше, данная статья является продолжением моей статьи: Как сделать мини-экран для Умного Дома Яндекс (УДЯ) за 659 рублей?

Идея: вместо того, чтобы каждый раз спрашивать у Алисы «какая температура на улице», «Какое содержание углекислого газа в комнате» и «состояние окна» поставить маленькую коробочку, на экране которой эта информация будет отображаться постоянно.

Глобально, новая версия прошивки YaMon отличается от описанной с первой статье тем, что для ее использования нужна только железка, умение внимательно читать инструкцию (эту) и тыкать мышкой в браузер. Навыки программирования теперь не требуются.

Благодарности:

  • Алексею Лущикову, который припаивал провода к FoBoTV (клону SmallTV Ultra), который, как выяснилось, я к тому времени уже спалил пытаясь найти правильную схему подключения этих проводов, чтобы скачать оригинальную прошивку и NEIMZ мини (другой клон SmallTV Ultra), который в результате удалось корректно перешить, и который есть на первой фотографии.

  • Вадиму @tzirulnicov за статью: “Подключение самодельных устройств к умному дому Яндекса с Алисой”, с которой, собственно, я этой темой и занялся (см. первую часть).

  • ИИ от Google, который написал весь Web-интерфейс YaMon и YaMon Migrator и очень сильно помог мне в оптимизации кода back-end и его портировании на ESP32.

  • ИИ «Алиса» от Яндекс – ее вклад значительно меньше, но некоторые моменты, на которых ИИ от Google откровенно тупил, она помогла мне решить. Например, на вопрос: чем заменить «ESP.wdtFeed();» на ESP32, корректно ответила только она.


Основные изменения от версии, описанной в предыдущей статье:

В конце первой части я писал о своих планах по дальнейшему развитию проекта. Некоторые вещи оказались сильно сложнее, чем я ожидал, но, в целом, все готово.

Разумеется, в системе есть много багов, а некоторые из них, в JavaScript на HTML страничках я знаю, но сам исправить не могу, так что буду благодарен за подробные баг-репорты, особенно, если они будут сразу идти с исправленным кодом.

Все критичные нюансы в работе системы я, вроде бы, исправил, так что если Вы сделаете бакап с помощью YaMon Migrator, а потом не будете обновлять прошивку на другую архитектуру, то все потенциальные проблемы можно будет решить без использования прошивки по кабелю.

Разумеется, если Вы прошьете в SmallTV Ultra прошивку для ESP32, прошьете в SmallTV Pro прошивку для ESP-12F или вообще загрузите мою прошивку в железку, на которую она не рассчитана, то для восстановления ее работы, в лучшем случае, потребуется подключение по кабелю.

В общем, перефразируя лицензию GPL: «Я отдаю вам свой код бесплатно, но без каких-либо гарантий и, в любом случае, не буду нести за это никакой ответственности», «Вы можете использовать его любым способом, но за любые результаты такого использования Вы отвечаете сами» и «Единственное требование, которое на Вас налагает эта лицензия: при любых изменениях указывать, где вы взяли мой код YaMon» – не уверен, что формулировки юридически корректны, но мы же не в суде… Я так, подстраховался на всякий случай 😉

Главное:

  • Исходный код более не содержит никаких приватных данных: идентификаторов, паролей и т.п. Вместо этого, все настройки задаются через web-интерфейс и хранятся в Preferences.

И с этим на SmallTV Ultra (ESP-12F на базе SoC ESP8266) возникли проблемы:

1) Прошивка GeekMagic использует схему разбивки диска (flash partitioning) с файловой системой LittleFS размером 3МБ, что на диске размером 4МБ, в силу особенностей архитектуры ESP8266, ограничивает максимальный размер прошивки до 512КБ, а текущая прошивка YaMon занимает почти 800КБ.

В результате, прямое обновление на нее через web-интерфейс оригинальной прошивки GeekMagic невозможно.

2) Прошивка GeekMagic хранит на этой ФС не только настройки, но и файлы web-интерфейса и если ей не удается смонтировать ФС и достать до этих файлов, то она просто бесконечно перезагружается.

Т.е. если просто перешить железку на YaMon по кабелю, то с вероятностью 50% (особенности архитектуры ESP8266) файловая система SmallTV Ultra будет испорчена, и при возврате прошивки от GeekMagic Вы получите железку, которая будет постоянно перезагружаться.

3) Прошивка YaMon использует для хранения параметров библиотеку Preferences, но так как у ESP8266 нет этой библиотеки и вообще, нет места для хранения NVRAM (NVS) я использую библиотеку  https://github.com/vshymanskyy/Preferences, которая физически хранит эти данный в виде файлов LittleFS, для чего она автоматически создается на последнем 1МБ диска.

Т.е. при первом запуске прошивки YaMon файловая система SmallTV Ultra будет испорчена с вероятностью 100% и при возврате прошивки от GeekMagic Вы точно получите железку, которая будет постоянно перезагружаться.

4) У меня есть две SmallTV Ultra. С первой я прошивку не догадался сохранить, а со второй сохранил, но если ее залить на первую железку, то она постоянно перезагружается.

Я не знаю связано это с какими-то мелкими аппаратными отличиями между железками или это защита от копирования, но у меня это точно не работает.

Т.е. для возврата на оригинальную прошивку нужно использовать именно ту ФС, которая была именно на этой железке до миграции.

Для решения всех этих проблем я сделал отдельную прошивку: YaMon Migrator – она достаточно мала, чтобы ее можно было загрузить через web-интерфейс оригинальной прошивки от GeekMagic или через такой-же интерфейс YaMon.

Она ничего не пишет на диск самостоятельно, но умеет бакапить существующие данные и восстанавливать эти бакапы. Про нее подробнее написано далее в разделе «Процедура миграции на YaMon и возврата назад».

  • Добавлена поддержка SmallTV Pro (SoC ESP32-WROOM-32)

Это гораздо более мощная и сложная система, у которой нет перечисленных выше ограничений, так что я просто сделал в YaMon для ESP32 ту же таблицу разделов и теперь можно вполне безопасно мигрировать оригинальную прошивку на YaMon и обратно без YaMon Migrator, но его я, на всякий случай, на эту платформу тоже портировал – просто, чтобы там тоже была возможность делать резервные копии разделов и их восстанавливать.

  • Сделана процедура получения Яндекс-токена для доступа в УДЯ, его автоматического продления, а также выбор датчиков через web-интерфейс.

Т.е. теперь YaMon не требует умения программировать и его может использовать кто-угодно.

  • Сделана куча разнообразных доработок, в результате чего объем кода увеличился в разы, а его сложность на порядок.

Подробности описаны в отдельном разделе «Исходный код, нюансы, сложности и трудные решения», который можно пропустить, если не интересно.


Первоначальная настройка и использование YaMon

Эта часть описывает что нужно делать после первого запуска прошивки YaMon.

Как правильно мигрировать с оригинальной прошивки, чтобы потом можно было вернуться назад, описано в следующем разделе. Так что перед тем, как это делать, я рекомендую Вам его прочитать.

Немного нелогично, но, мне кажется, что так понятнее. Тем более, что при прошивке по кабелю это реально то, что Вы увидите сразу после прошивки.

Последовательность:

  1. Подключение к AP и настройка параметров WiFi:

  2. Получение Яндекс-токена

  3. Настройка дополнительных параметров (можно пропустить)

  4. Выбор датчиков УДЯ (Умного Дома Яндекс)

1. Подключение к AP и настройка параметров WiFi:

На старте прошивка YaMon пытается прочитать параметры. Если это первый запуск и параметров нет, то она автоматически из создаст со значениями «по умолчанию».

Тут важно то, что на ESP-12F (Ultra, Crystal Cube и т.п.) это создаст раздел LittleFS на последнем, четвертом мегабайте флеш-диска, что гарантировано уничтожит файловую систему (ФС) оригинальной прошивки. Как ее сохранить — написано в следующем разделе. Зато, на ESP32 (Pro) это просто добавит параметры в NVRAM (NVS), что никому и ничему не помешает.

После этого, железка перейдет в режим AP (WiFi AccessPoint) и создаст собственную сеть YaMonAP_XXXX, где XXXX – последние два байта MAC-адреса в шестнадцатеричном виде.

Вот это будет нарисовано на экране:

Первый QR-код: подключение к сети WiFi

Первый QR-код: подключение к сети WiFi
Второй QR-код: ссылка на http://192.168.4.1/

Второй QR-код: ссылка на http://192.168.4.1/

Первый QR-код – специальный код для подключения к WiFi, а второй: просто ссылка http://192.168.4.1/. Тут важно, что именно «http:», а не «https:» – современные браузеры при каждом удобном и неудобном случае меняют «http:» на «https:», а по HTTPS подключиться не получится.

Еще нюанс, касающийся Crystal Cube: на данном этапе экран не зеркалируется, но это не проблема – нужно просто снять стеклянный кубик и смотреть на реальный экран.

Далее нужно подключиться к этой AP, а потом в к этому сайту и Вы увидите вот такую страничку:

Окно первоначальной настройки YaMon

Окно первоначальной настройки YaMon

На ней нужно указать имя и пароль WiFi-сети. Можно нажать на кнопку «Сканировать» и тогда вместо ввода имени можно будет выбрать его из списка, но пароль все равно придется вписать руками.

Замечание: если WiFi-сеть в настройках указана, но за 2 минуты к ней не удалось подключиться, то железка переходит в тот же самый режим AP, но в соответствующих полях будет уже указаны имя и пароль сохраненной WiFi-сети, а еще на экране будет ссылка на /settings.

В этом случае у Вас есть 4 варианта:

  1. Перезагрузить – если это был временный сбой и сейчас сохраненная WiFi-сеть уже активна.

  2. Указать новую WiFi-сеть – если старая, по какой-то причине, уже не актуальна.

  3. Перейти на http://192.168.4.1/settings и добавить в список новую сеть (YaMon поддерживает до 5 WiFi-сетей), сохранив все остальные настройки.

  4. Сбросить все сохраненные настройки (использую соответствующую кнопку) и настроить все с нуля.

В любом случае, здесь Вы можете поменять имя железки (это удобно, если у Вас их несколько), выбрать правильный часовой пояс и включить зеркалирование экрана для Crystal Cube.

Но все эти настройки можно сделать и позже, используя /settings.

2. Получение Яндекс-токена

После указания параметров WiFi-сети железка перезагрузится, в браузере будет вот такая инструкция, а на экране вот такая картинка:

Инструкция по получению токена

Инструкция по получению токена
Код для получения токена

Код для получения токена

Нужно перейти по указанной ссылке, ввести там указанный на экране код и подтвердить разрешение на чтение данных с Вашего УДЯ.

После этого железка еще раз перегрузится, покажет Вам время и дату, но ничего больше показывать не будет, потому что ей не сказали какие конкретно датчики нужно опрашивать.

Это выглядит вот так:

Первый запуск: есть валидный токен, но нет информации о датчиках, которые нужно опрашивать

Первый запуск: есть валидный токен, но нет информации о датчиках, которые нужно опрашивать

Нужно зайти браузером на указанный IP-адрес и настроить железку:

Главная страница YaMon

Главная страница YaMon

Сначала заходим в «Системные настройки» и выставляем нужные параметры:

Настройки YaMon: /settings

Настройки YaMon: /settings

Тут можно поменять имя, часовой пояс, уровень подсветки, включить зеркалирование экрана, изменить список WiFi-сетей, NTP-серверов и запущенных сервисов (например, можно выключить OTA).

Следующий шаг: выбор и настройка датчиков УДЯ:

Настройки YaMon: /yandex

Настройки YaMon: /yandex

Первый шаг: нажимаем на кнопку «Запросить данные у Яндекс» и ждем пока они загрузятся – время зависит от кол-ва датчиков. У меня 13-15 секунд.

Если все прошло успешно, то картинка будет такая:

Настройки YaMon: /yandex - после загрузки JSON с Яндекс

Настройки YaMon: /yandex — после загрузки JSON с Яндекс

Нажимаем на «Выбрать», выбираем «Умный Дом» и «Устройство» и нажимаем на «Вставить ID»:

Настройки YaMon: /yandex - выбор датчика

Настройки YaMon: /yandex — выбор датчика

Картинка меняется:

Настройки YaMon: /yandex - после выбора датчика, но до его сохранения

Настройки YaMon: /yandex — после выбора датчика, но до его сохранения

Нажимаем на «Применить» и картинка меняется опять: Активируется кнопка «Получить данные», после чего мы на нее нажимаем и убеждаемся, что параметры «по умолчанию» к нашему датчику подходят: видим реальные цифры, полученные с этого датчика:

Настройки YaMon: /yandex - после сохранения и получения актуальных значений

Настройки YaMon: /yandex — после сохранения и получения актуальных значений

Если что-то пошло не так (вместо зеленых цифр со значениями параметров вы видите красные сообщения об ошибке, то Вы можете выбрать правильную «секцию» JSON, содержащую нужные параметры и имена самих параметров, нажимая соответствующие кнопки. Если с выбором из списков что-то не сложилось, то Вы всегда можете просто поправить текстовые строчки в соответствующих полях.

Примечание: При обращении к web-интерфейсу штатные запросы к Яндекс блокируются на одну минуту, но, чтобы увидеть те же цифры на экране YaMon мы можем нажать на кнопку «Проверить». Перед продолжением настройки желательно нажать на ту же кнопку, которая теперь будет называться «Закончить проверку», чтобы штатные запросы значения датчиков не мешали настройке.

Эти действия нужно повторить для всех датчиков, а потом нажать на кнопку «Проверить» и убедиться, что все работает как задумано.

Если все хорошо, то нужно отмотать страничку вверх и нажать на «Сохранить изменения и Перезагрузить», а если что-то пошло не так и непонятно как это исправить, то нажать на «Забыть изменения и Перезагрузить», зайти на эту страничку еще раз и еще раз попробовать все настроить:

Настройки YaMon: /yandex - сохранение изменений

Настройки YaMon: /yandex — сохранение изменений

 

Отдельно хочу написать про страничку /help:

Она показывает «живой» экран YaMon с актуальными цифрами, правда обновляющийся 1 раз в минуту, на котором можно ткнуть в конкретную область экрана и увидеть объяснение того, что это за цифра:

Страничка помощи YaMon: /help

Страничка помощи YaMon: /help

Процедура миграции на YaMon и возврата назад

Для начала нужно определить какой SoC используется в Вашей железке. Самый надежный способ: разобрать и посмотреть что написано на микросхеме, но и там не всегда есть надпись ESP-12F или ESP32-WROOM-32.

Я тестировал эту прошивку только на железках, перечисленных на первой фотографии этой статьи, но, теоретически, она должна работать и на всех их клонах:

  • Если это клон SmallTV Pro (есть сенсорная кнопка, а на микросхеме написано что-то начинающееся с ESP32 или GM32), то нужно выбирать прошивку ESP32.

  • А если кнопки нет, а на микросхеме написано что-то начинающееся с ESP-12 или ESP8266, то это, скорее всего, клон SmallTV Ultra.

Впрочем, в клонах может использоваться тот же SoC, но периферия может быть распаяна по другому. Так что никаких гарантий я дать не могу.

А еще, теоретически, Вам может попасться железка на базе современных процессоров ESP32, например ESP32-C6 или ESP32-S3 – на них эта прошивка точно работать не будет. Хотя, их поддержка есть в моих планах (см. последний раздел этой статьи).

Зато, дальше этих проблем не будет: и сам YaMon и YaMon Migrator в версии прошивки указывает архитектуру, так что при обновлении или миграции нужно просто скачивать свежую прошивку для той же архитектуры.

Последовательность действий, чтобы мигрировать SmallTV Ultra на YaMon (esp12f):

1) Скачиваем с https://gitflic.ru/project/stacez/yamon/release/ последние версии прошивок YaMon (yamon_<arch>_fw_<версия>.bin) и YaMon Migrator (yamon-migrator_<arch>_fw_<версия>.bin), где «<arch>» – это нужная архитектура (esp12f или esp32).

Список релизов YaMon

Список релизов YaMon
Список доступных для скачивания прошивок выбранного релиза

Список доступных для скачивания прошивок выбранного релиза

2) Заходим на web-интерфейс оригинальной прошивки, и убеждаемся, что архитектура выбрана верно:

Настройки SmallTV Ultra - проверяем архитектуру

Настройки SmallTV Ultra — проверяем архитектуру

3) Выбираем «Firmware update» и загружаем файл YaMon Migrator (yamon-migrator_esp12f_fw_v1.0.1.bin).

Настройки SmallTV Ultra - обновление прошивки

Настройки SmallTV Ultra — обновление прошивки

 

4) Ждем окончания прошивки. Если все сделано правильно, то железка перезагрузится, запустит Migrator и напишет как подключиться к его Web-интерфейсу.

Хочу отметить, что мигратор пытается найти настройки WiFi и, если ему это удается, сначала пытается подключиться к ней и запускает свою AP только, если это не удалось. Поиск ведется так: сначала берутся настройки YaMon, если они не найдены, то он ищет файл config.json в LittleFS, а если и тут ничего не получается, то пытается найти последнюю, сохраненную системой, WiFi-сеть.

В данном случае, диск в оригинальном состоянии, так что ничего найти не удалось и он запустил собственную AP:

Первый запуск YaMon Migrator

Первый запуск YaMon Migrator

 

5) Подключаемся к указанной сети и заходим на указанную ссылку

YaMon Migrator (ESP-12F): резервное копирование оригинальной прошивки

YaMon Migrator (ESP-12F): резервное копирование оригинальной прошивки

Видим, сообщение о том, что «Найдена неизвестная файловая система» и делаем ее резервную копию на случай, что потом решим вернуться на оригинальную прошивку.

Если мигратор найдет раздел YaMon, то он про это напишет, загрузит имя системы и настройки сети и тоже предложит сделать резервную копию, но ее размер будет уже не 3МБ, а всего 1МБ.

Вот так это будет выглядеть:

YaMon Migrator (ESP-12F): резервное копирование параметров YaMon

YaMon Migrator (ESP-12F): резервное копирование параметров YaMon

6) Если у нас уже есть резервная копия диска пришивки, на которую мы хотим перейти, то нужно ее восстановить. Если нет, то этот пункт нужно пропустить и перейти к обновлению прошивки.

Важно: категорически не рекомендуется выполнять восстановление данных при подключении к AP на ESP-12F (по адресу: http://192.168.4.1/)!

Дело в том, что стирание флеш-памяти достаточно длительная процедура (до нескольких секунд) и в этом время AP будет недоступна, что может заставить Ваш ПК переключиться на другую сеть. Если он это сделает, то восстановление данных закончится ошибкой или просто зависнет! Если Вам необходимо это сделать, то сначала прошейте YaMon (или оригинальную прошивку) настройте там подключение к WiFi, а потом еще раз прошейте мигратор и выполняйте операцию восстановления, подключившись к другой WiFi-сети.

YaMon Migrator (ESP-12F): восстановление резервной копии

YaMon Migrator (ESP-12F): восстановление резервной копии

Выбираем тип резервной копии, указываем файл в который мы его сохраняли, нажимаем на кнопку и через некоторое время получаем:

YaMon Migrator (ESP-12F): Успешное восстановление резервной копии

YaMon Migrator (ESP-12F): Успешное восстановление резервной копии

7) Обновляем прошивку на YaMon

YaMon Migrator (ESP-12F): загрузка новой прошивки

YaMon Migrator (ESP-12F): загрузка новой прошивки

Смотрим на строчку «Текущая версия прошивки: 1.0.1 (ESP-12F)» и убеждаемся, что мы скачали прошивку YaMon под правильную архитектуру.

8) Нажимаем «Обновить прошивку», выбираем нужный файл (В данном случае: yamon_esp12f_fw_v2.0.4.bin) и ждем окончания процесса.

Если на диске есть правильная конфигурация для загруженной прошивки, то все должно заработать, а если конфигурации нет, то YaMon нужно настроить с нуля (см. предыдущий раздел).

Возврат на оригинальную прошивку выполняется в обратном порядке:

1) Убедитесь, что в YaMon настроена правильная сеть WiFi (что Вы подключаетесь к YaMon НЕ по адресу: http://192.168.4.1

2) Убедитесь, что у Вас есть прошивка YaMon Migrator под правильную архитектуру, а также есть прошивка от оригинального вендора. Например: https://github.com/GeekMagicClock/smalltv-ultra/tree/main/Ultra-V9.0.50

Архитектуру можно посмотреть на страничке обновления прошивки YaMon:

YaMon (ESP-12F): загрузка новой прошивки

YaMon (ESP-12F): загрузка новой прошивки

3) Обновитесь на YaMon Migrator и убедитесь, что он успешно запустился и подключился к нужной сети (см. предыдущую инструкцию, начиная с п.5.)

4) Сохраните, на всякий случай, настройки YaMon, а потом восстановите «Данные другой прошивки» из файла, который Вы сделали при миграции на YaMon (см. п.7 предыдущей инструкции).

5) Обновите прошивку, используя файл, полученный от оригинального производителя (см. п.7 предыдущей инструкции).

Для SmallTV Ultra необходимо скачать, по указанной выше ссылке, zip-файл, распаковать его и использовать для обновления файл FW-Smalltv-Ultra-V9.0.50.bin.

С SmallTV Pro (ESP32) Все проще: оригинальная прошивка от GeekMagic и YaMon друг другу не мешают: YaMon использует для хранения настроек имеющийся на этой железке раздел NVS и не трогает файловую систему GeekMagic, а места достаточно, так что можно обновиться на YaMon используя web-интерфейс SmallTV Pro, и вернуться назад на оригинальную прошивку, используя web-интерфейс YaMon.

Но я сделал версию YaMon Migrator и для ESP32 – с его помощью можно сделать резервные копии NVRAM (NVS) и файловой системы, а потом их восстановить.


Исходный код, нюансы, сложности и трудные решения

Думал, что эту будет самый длинный раздел, то и так получился большой объем, так что постараюсь покороче.

Исходный код по прежнему выложен на https://gitflic.ru/project/stacez/yamon

Только теперь там 3 скетча:

  • yamon_esp12f – архивная версия 1.0.1, работающая только на ESP-12F (для истории).

  • yamon – актуальная версия YaMon (2.0.4), поддерживающая и ESP-12F и ESP32, о которой эта статья.

  • yamon_migrator – актуальная версия YaMon Migrator (1.0.1)

Поясню почему так получилось: первоначально я собирался писать эту статью про yamon_esp12f и даже залил актуальную на тот момент версию на Git, а потом решил, чтобы «два раза не вставать», сразу сделать порт на SmallTV Pro (ESP32), так появился скетч yamon версии 2.0.1, который отличался от 1.0.1 только поддержкой ESP32.

Текущая версия 2.0.4 не сильно отличается от 2.0.1, но эти изменения в yamon_esp12f уже не попали. В общем, по хорошему, yamon_esp12f нужно удалить, но я решил, что пусть пока полежит. Потом удалю.

Еще одно отличие в том, что yamon_esp12f  писался на Arduino IDE 2.3.8, а yamon и yamon_migrator уже портированы на PlatformIO (точнее, на pioarduino). Я старался сделать так, чтобы на Adruino IDE эти проекты тоже собирались, но тестировались они только на PlatformIO.

Обещанные нюансы и сложности:

Сначала у меня были большие проблемы с ОЗУ на ESP-12F, поэтому существующий код был переписан почти полностью, чтобы максимально убрать все типы «String», заменив их на «char var[]», а там где это было возможно, вообще на «static const char PROGMEM var[]», чтобы эти данные читались напрямую с флеш-диска.

Кроме этого, я реализовал сложную систему состояний. В подсказке ей посвящен целый раздел:

YaMon: подсказка - описание режимов работы

YaMon: подсказка — описание режимов работы

По железка все равно периодически возвращала ошибки обработки и даже падала из-за нехватки памяти.

Дело в том, что у ESP-12F всего 80КБ ОЗУ, из которых для приложений остается доступными около 40КБ, так что мне приходилось считать каждый байт.

А потом я определил главного «пожирателя» ОЗУ: структура «BearSSL::WiFiClientSecure» занимает более 20КБ и когда она объявлялась в каждой функции отдельно, то память фрагментировалась, а периодически вообще попытка выделения памяти под новую структуру осуществлялась еще до того, как освобождалась старая – это стабильно приводило к падению по OOM.

После того, как я сделал эту структуру глобальной и начал в ручном режиме выделять и освобождать ее память, то для моего, уже оптимизированного, кода памяти стало достаточно и сбои прекратились. Но я не стал убирать уже написанный код для управления режимами:

  • «запросы состояния УДЯ» – которые у меня скачивают >370КБ JSON и анализируют их, причем делают это «налету», так как в памяти объема для их хранения нет, а нужно успеть скачать все до того, как у Яндекс закончится таймаут.

  • Обновления по OTA – которые Вам теперь не нужны, если только Вы не планируете менять исходный код.

  • Web-сервер, причем если он отключен и железка была трижды перезагружена, проработав менее 1 минуты, то он автоматически включается.

Я решил, что по умолчанию все эти параметры будут включены, но их можно будет отключить, например, из соображений безопасности – если отключить и OTA и web-сервер, то для того, чтобы что-то сделать с железкой, потребуется физическая возможность отключать и включать ее питание.

Отмечу, что весь web-интерфейс написан Google ИИ (бесплатным, доступным через поиск на google.com). Точнее, первую версию написал я, но это была некрасивая страничка с формами, в которые нужно было вписывать те же параметры, которые ранее задавались в исходном коде, и после каждого нажатия на кнопку браузер переходил на новую текстовую страничку с результатом выполнения, а потом нужно было руками возвращаться назад.

ИИ сделал мои странички красивыми, с кучей JavaScript, а мои старые текстовые странички по прежнему видны, но в красивом всплывающем окошке, которое рисуется поверх основной странички.

А еще я попросил ИИ сделать кнопки выбора датчиков, анализируя тот же большой JSON от Яндекс – у браузера–то тет проблем с выделением 400КБ ОЗУ под буфер, но оказалось, что Яндекс не озаботился заголовками «Access-Control-Allow-Origin:», в результате чего современные браузеры отказываются обращаться к нему за данными.

Пришлось делать на железке proxy, но тут оказалось, что она не в состоянии прокачать весь этот JSON за отведенное время. Т.е. Скачать она его может, а вот выдать наружу успевает только около 190КБ из 377КБ. Так что пришлось делать не просто proxy, а потоковый сканер JSON, вырезающий из большого JSON только нужные параметры из нужных разделов, причем только на указанной глубине вложенности, так как многие параметры в этом JSON повторяются многократно.

В результате, получилась сложная схема, которая, вроде бы, работает вполне стабильно. Именно к ней обращаются кнопки, расположенные на страничке /yandex YaMon.

А потом я попросил ИИ переписать мою функцию getYandexInfo() использую ту  же технику, чтобы обеспечить возможность ее прерывания в любое время – раньше на время ее выполнения все блокировалась, а работает она на моем УДЯ 13-15 секунд, что очень сильно мешало работе кнопок на страничке /yandex и OTA-обновлениям.

Еще хочу отметить, что теперь есть штатная поддержка отдельного датчика CO2, а на страничке /yandex есть специальная галочка, включающая этот режим.

Кроме этого, теперь если информация о датчике не указана, то он просто не запрашивается, и никаких ошибок это не вызывает. Т.е. YaMon можно использовать как часы. Правда, непонятно зачем 😉


Используемое у меня оборудование

Оборудование то же самое, которое я описывал в предыдущей статье:  Как сделать мини-экран для Умного Дома Яндекс (УДЯ) за 659 рублей?

Добавилась железка SmallTV Pro, которую я покупал еще в феврале и сейчас Aliexpress говорит, что такой странички не существует.

Добавилась вторая SmallTV Ultra: https://aliexpress.ru/item/1005011753956461.html, которую я купил специально, чтобы скачать файловую систему, но эта ФС к старой Ultra почему-то не подходит – я про это написал в разделе про миграцию.

Кстати, она сильно подешевела: ее я купил за 420 руб., а не за 659, как в феврале.

Отдельная история про «Настольные часы NEIMZ мини с метеостанцией WiFi»: https://aliexpress.ru/item/1005009396217720.html ее я купил (кстати, всего за 329 руб.) потому, что увидел в отзывах предупреждение, что если подключить ее к компьютеру, то она пишет имя и пароль WiFi-сети, указанной в настройках…

А значит, рассудил я, там внутри уже есть конвертор и ее можно подключать по кабелю без специальных приспособлений и даже не разбирая…

Но в приехавшем мне экземпляре конвертор распаян не был, контактов, как в оригинальном SmallTV тоже не было, а были только пустые посадочные места для распайки конвертора.

Так что когда я по ошибке залил в него через web прошивку мигратора для ESP32, то получил «кирпич». Сначала я обратился к ИИ Google, чтобы он подсказал как подключить к этим дорожкам CG Programmer, но после третьей предложенной схемы, в очередной раз «Абсолютно точно правильной», я вспомнил судьбу FoBoTV – такого же кубика, но от других китайцев, который я просто сжег выполняя инструкции ИИ Google, и попросил помочь нашего сервисного инженера Алексея Лущенко: я дал ему эту железку, рабочую железку SmallTV Ultra вместе с описанием ее контактов + даташит от AI-Thinker, а в результате получил плату с припаянными проводами, которая после подключения к CG Programmer позволила мне железку перешить и сейчас она прекрасно работает.

На всякий случай, вот распайка, на которой указаны контакты CG Programmer, к которым эти дорожки платы нужно подключать:

Плата NEIMZ мини - вид сверху

Плата NEIMZ мини — вид сверху
Плата NEIMZ мини - вид снизу

Плата NEIMZ мини — вид снизу

 

Еще раз повторю: надписи на картинках – это не названия контактов платы, а названия контактов CG Programmer, к которым их нужно подключать.

Например: контакт подписанный «RX» — это «TXD0», который нужно подключить к  контакту «RX» CG-Programmer, а «EN» — это «RST», который нужно  подключить к контакту «EN» CG-Programmer.

Может кому пригодится. 


Эпилог: планы на будущее

А теперь о приятном: почти все планы, которые я заявлял в первой статье, я уже реализовал. Осталось три момента

  1. «Сделать отдельную «Тему» для Crystal Cube: показывать время ближе к центру, увеличив размер шрифта, а данные с датчиков по очереди. По несколько секунд каждый.»

Это я по прежнему планирую когда-нибудь сделать. Разумеется, это будет не отдельная прошивка для CC, а переделка всего YaMon.

Но думаю, что это будет последнее изменение функционала для ESP-12F.

  1. «Попробовать этот скетч на SmallTV Pro. У нее более мощный SoC (ESP32-WROOM-32), а еще есть сенсорная кнопка,  которой можно переключать режим отображения.»

Скетч портирован на ESP32, но пока работает точно так же, как на ESP-12F. На данный момент я думаю, что после добавления тем (см. предыдущий пункт) нажатие на эту кнопку будет их переключать.

Но, как говорит мой сын: «это не точно».

  1. «Портировать его на какую-нибудь железку с экраном 4-10″, которую можно прикрутить или приклеить к стене.»

А вот тут планы стали более определенными: я уже купил себе «ESP32-4848S040C 4-дюймовый ЖК-модуль TFT»: https://aliexpress.ru/item/1005006622746590.html

Это готовая железка, вставляющаяся в китайскую розетку, имеющая современный SoC ESP32-S3, экран 4 дюйма с тачем, питание от 220В и встроенное реле 220В на 3 нагрузки.

Я прочитал про нее вот тут: https://mysku.club/blog/aliexpress/100157.html

В общем, она прямо напрашивается на то, чтобы сделать какой-нибудь YaMon Pro, который будет не только показывать состояние устройств, но и управлять ими.

Но это, опять же, неизвестно когда и если лень позволит…

Засим прощаюсь, надеюсь, что это кому-нибудь, кроме меня, интересно 😉

ссылка на оригинал статьи https://habr.com/ru/articles/1052388/