В этом опусе я написал о буднях программиста микроконтроллеров в России.
Что вообще пишут программисты МК и на чем?
Основной язык программирования это С. Языку С уже более 50 лет. Язык С потихоньку сдает свои позиции. Кроме микроконтроллеров С уже практически никому не нужен. Навыки программирования на С очень слабо конвертируются. В свое время, видимо, на С написали компилятор для С++ и нужда в С для desktop как таковая отпала. Есть конечно DeskTop проекты написанные на С: Git, JVM, MySQL, Nginx, PostgreSQL, TaranTool, WallArm, однако вероятность, что в этих проектах можно работать из РФ да еще и с опытом из электроники мала. A сам язык С остался для сборки артефактов для микроконтроллеров с экстремально малыми ресурсами (для automotive ECU, SIM карт, IoT). Хотя и сейчас большинство компаний в Евросоюзе уже давно как и микроконтроллерные сборки собирают на С++ 17 и выше. Вероятно, что язык программирования С для МК вскоре и вовсе войдет в историю.
Еще программистам MК приходится обсчитывать аналоговые цепи и вычислять какие-то сложные 8-этажные формулы для настройки PLL таймеров и строить графики. Обсчитывать сигналы post-procсessing(а) в трактах цифровой обработки сигналов (ЦОС/DSP). Для этого практикуют бесплатный интерпретатор Python и модули matplotlib, math, numpy, scipy и т. п.
Главным образом программисты микроконтроллеров составляют MCAL, HAL, Board Support Package (BSP), пишут драйверы для новых умных периферийных ASIC чипов c управлением по интерфейсам I2C/SPI/MDIO/1Wire/UART/SMBus/PMBus, пишут загрузчики, портируют RTOS(ы) на разные процессорные ядра, пишут код-генераторы, скрипты сборки, составляют модульные тесты, изредка производят рефакторинг, часто чинят ошибки в Legacy коде, изредка что-то изменяют в коде Assembler(а), который запускается до вызова функции main().
Некоторые компании сами пишут своё system software базового уровня. Так называемый MCAL, HAL, SPL. Даже вопреки тому, что этот код бесплатно в открытом виде дают производители всех микроконтроллеров.
Поэтому программисты-микроконтроллеров годами пишут эти драйверы самого низкого уровня для того чтобы пользоваться GPIO, UART, PWM, ADC, DAC, CAN, I2C, SPI, I2S, DMA. По сути это код-переходник между удобной функцией
bool uart_write_data(uint8_t num, uint8_t* const data, size_t size);
и чтением и записью сырых физических регистров, что в карте памяти данного MCU. Ниже кода просто не бывает... Тут кроме конечных автоматов там ничего больше не нужно.
Иногда программист МК даже ничего и не пишет сам вообще! Важно уже не сколько уметь программировать, сколько уметь составлять модульные тесты, собирать, улучшать из готового кода из интернета. Какие-то исходники можно взять из github или ядра Linux. Можно раздербанить Zephyr Project. Там есть код на многие темы. Драйверы для множества чипов. Важно уметь верифицировать найденные сорцы и аккуратно подключить их к нужной сборке.
Программирование на Си в Linux
Справедливости ради стоит упомянуть, что С используют для создания модулей ядра Linux. Как вариант можно пойти работать туда. Но надо быть готовым, что образ дистрибутива будет собираться по часу. В Linux проектах ещё больше бюрократии и секретности, чем в проектах на МК. И С кода в Linux пишут существенно меньше. Разработка в Linux похожа на прикладывание костылей. Вся эта методология device tree overlay - это по сути узаконивание костыллинга и быстрых заплаток в разработке.
Часто Linux программисты даже никогда не видели схемотехнику своего target устройства SBC и datasheet(а) на SoC (так как это секрет компании). Программисты Linux работают в абстрактных условиях. Редактируют дерево устройств DTS, путешествуют по файловой системе, пишут скрипты на Bash и Python, исправляют баги в JavaScript(е) Web GUI и выносят ведрами баги из кода User Space процессов для отладки, перекраивают дерево устройств *.dts, добавляют драйверы чипов в загрузчик U-Boot и пишут очень много документации и инструкций (Doc Food(а)) на LaTeX.
Они в принципе не работают в Windows. Собирают ядро для Linux из-под Linux (Ubuntu или CentOS) или на удаленных серверах целыми месяцами напролет глядя в черный экран терминала vim по ssh. Тоска зелёная!
И потом, Linux kernel программисты очень скептически относятся к тем, кто пришел в Linux kernel из программирования микроконтроллеров.
Во первых все кто пришел в Linux из микроконтроллеров это 90% Window (ятники). Это первая причина отсутствия обшей почвы под ногами с Linux программистами. Потом средства отладки в Linux kernel и MCU совершенно разные, разные системы сборки, разный способ передачи конфигов в программы, разный исходный набор документации, разные традиции оформления кода. Всё разное, понимаете! Только Си язык одинаковый. Фактически Linux разработчики даже не считают программистов-микроконтроллеров программистами как таковыми. Называют их User(ы) GUI(нёвых)-IDE(шек)!
Поэтому закрепиться в коллективе Linux программистов программисту микроконтроллеров получится не с первой, и даже не со второй попытки.
Как проходят собеседования на роль программист микроконтроллеров?
Собеседования на роль программист микроконтроллеров это вообще тема для анекдотов. Первый вопрос, который обычно задают программистам микроконтроллеров грубым голосом и ультимативным тоном звучит так:
Ты будешь печатные платы разводить?
Это, напомню, на роль "программист". Второй вопрос как-то ближе к теме. Звучит так:
Ты будешь на ассемблере программировать?
Еще есть такие варианты
Согласен заниматься реверс инжинирингом?
Если ответы нет/нет/нет то работу точно не получишь...
В Российском рынке электроники есть одна любопытная закономерность. Чем более ответственный проект и разработка тем, как не странно, проще туда устроиться на работу программистом микроконтроллеров. Мой самый простой job offer, где я, к слову, накосячил во всём: опоздал на 45 минут, cначала вошёл не в то здание, пришел в шортах и гавайской рубашке, ничего не решил на тестовом задании, я получил в компанию, которая разрабатывает авионику для российского пассажирского авиалайнера MC-21! А самое-самое трудное собеседование в моей жизни, где меня гоняли по всему MIT(шному) курсу Computer Science было в компанию, которая разрабатывает электронную папироску для вэйперов. Вот так, господа...
Также было очень легко получить предложение работы в компанию, которая разрабатывает активные фазированные антенные радио решетки АФАР для российских ударных дронов! И одновременно неимоверно сложно получить job offer в российскую компанию, которая делает офисную поилку с газировкой (там на устройстве поилки одна кнопочка всего: открыть кран с водичкой).
Кто-нибудь может объяснить мне, что, собственно, происходит в российской электронике?!
При устройстве в российское военное НИИ/НПЦ/ФГУП (на ЗП 22k...42k RUR/мес) с тебя потребуют пачку минимум из 16 документов, в числе которых будет даже справка от психиатра. Это, видимо, чтобы убедиться, что человек, который пришел в Москве работать на зарплату 42k RUR в месяц - это клинически не псих.
Иной раз видел, как наймут в НПЦ сотрудника программиста-микроконтроллеров, да никому нет до него дела. Новичок приходит на промзону и сидит без задания первые 4-5 недель. Потом только про него вдруг вспоминают и дают, наконец, какую-то задачу.
Программирование микроконтроллеров - это даже не профессия
Программирование микроконтроллеров - это зачастую даже не отдельная профессия.
В вакансиях часто пишут, что нужен прикладной программист DeskTop PC, там куча требований типа С++/C#, QT, JavaScript, базы данных SQL, JSON, Linux и в самом конце в обязанностях приписка программирование микроконтроллеров.
Или вакансия инженер-схемотехник. В требованиях подбор элементной базы, разработка схемотехники, трассировка печатных плат в Altium Designer, разводка BGA DDR памяти, трассировка шин PCI-Express, разводка топологии RF цепей, расчет импедансов, расчет радиаторов охлаждения, черчение корпусов блоков, bring-up электронных плат, а в самом конце маленькая приписочка - программирование микроконтроллеров.
Также программирование микроконтроллеров можно встретить в требованиях к FPGA разработчика: разработка RTL, написание Verilog кода, работа в IDE Vivado, IDE Qvartus и в конце приписка программирование микроконтроллеров.
Современный российские НИИ ну никак не хотят признавать программирование микроконтроллеров в отдельную специальность.
Причем в НИИ/НПЦ/ППК/ФГУП собеседования инженеров как правило в ультимативном тоне проводят женщины 40+ лет из отдела кадров с прошлым опытом работы в ЖКХ (найм дворников из средней Aзии). В технике они не шарят в принципе. Ну кто их посадил нанимать специалистов Hi-Tech электроники? Это как!?..
Вот такие вот, господа, пирожки с капустой, понимаете?..
Если вы устроитесь в какой-нибудь НИИ/НПЦ/ППК/ФГУП только программировать микроконтроллеры, то Вас оформят максимум на треть или даже четверть ставки.
Где работать программистом-микроконтроллеров? (Black Mesa по-русски)
В России программисты МК в основном работают в компаниях, которые делают госзаказ на военную технику, так называемые "аналогов нет"(ы).
Обычно чтобы попасть на рабочее место надо подойти к промзоне размером с аэропорт. До ближайшего метро минимум 3 км. Пройти вдоль советского вафельного бетонного забора метров 300.
Пройти сквозь вонючее КПП со злым как собака охранником. Пройти 300 метров по внутреннему дворику промзоны мимо полноростовых памятников (в масштабе Zoom 200%-300%) красных директоров этой организации. Зайди в ангаро-образное здание (Лямбда-комплекс сектора F), пройти ещё 3 турникеты, потом пройти еще 400 метров по коридорам и вот вы у своего коричневого верстака.
У каждой турникеты есть будка в которой сидит злой пожилой сторож, который может нажатием на кнопку заблокировать турникету, если ты ему вдруг не понравился. Курящие люди естественно ленятся выходить на улицу через всё зоны доступа (турникеты) и предпочитают курить свои скрутки и папироски прямо в уборных, которые уже к 13:00 превращаются в газовые камеры.
В самих помещениях как правило навалена всякая арматура и надо двигаться аккуратно чтобы опять не порвать себе штаны.
Здания старые настолько что даже ступеньки раскрошенные. Даже не знаешь куда и как ногу поставить. Подняться на 6й этаж - это как взобраться на угольный террикон. Лифты есть, но их включают только когда приезжает какой-то важный гость.
Плюс всяческие ритуалы. 20% вероятность, что на работе перед входом вас будут принуждать наклеивать на обувь антистатические наклейки, а иногда и облачаться в защитный костюм (душный комбинезон).
В России работа программиста MK происходит как правило в гаражных или около гаражных условиях. Или на чердаках-бардаках как тут
Провода. Высокое напряжение. Много какого-то металлолома возле компьютеров. Хлам на столах с горочкой. У вас под мониторами всегда будет валяться всякое барахло (отладочные модули, провода, коробки, чехлы, разъёмы, болты).
Вероятно, будешь работать по соседству с шумным охладительным оборудованием, так как электронные платы надо подвергать климатическим испытаниям. Там же рядом электронные платы будут сушиться после покрытия лаком, источая специфический запах.
У таких военных НИИ нет имени, нет сайта, или их сайт это просто баннер с нулевым функционалом. В отделе кадров даже не знают о существовании сайта hh.ru. Когда появляется вакансия до вакансии пишут от руки синей ручкой и приклеивают на скотч на стеклянных дверях промзоны предприятий. И люди всё равно охотно откликаются. Десятками! Причем, как не странно, приезжие. Даже из Сахалина. Видимо тупо нанимают родственников нынешних сотрудников и формально сажают на ставки схемотехников и программистов...
Начальники там как правило возрастом 60+. В одном НИИ я был свидетели как каждый день двое инженеров водили под руки начальника НИИ, чтобы тот просто мог дойти и поесть. Руководство не умеют пользоваться персональным компьютером и всю информацию получают исключительно только в картонных красных папочках. Исходные коды тоже иногда просят распечатать для них. Причем удивляет то, что просят чтобы исходный код был напечатан на миллиметровой бумаге! Сотрудники треть дня занимаются сплетнями, хвастаются отпусками. Особенно женщины. Вот так-то так...
В таких НИИ программистов и схемотехников периодически ещё заставляют писать подробные научные работы по каким-то ноу-хау в софте или железе, что есть в изделии. Аля-патент. Это весьма утомительно из-за обилия формул, схем, графиков и таблиц. Обычно писать такие тексты приходится по выходным, по вечерам и в гос. праздники, так как есть и основные задачи в будни. По сути ты описываешь, то, что сам сделал за полгода на 7-10 страницах.
Потом эту монографию публикуют в каком-н российском журнале при местном институте. Самое подлое в этой истории то, что там на первом месте оказывается фамилии начальника НИИ, начальника отдела и начальника лаборатории. А твоя фамилия, как фактического автора, в списке авторов либо в самом конце, либо и вообще выброшена! При этом поезд в списке указанных авторов к тексту, естественно, никакого отношения, как и к самой работе, не имели. Они текст даже не читали! У самого первого автора даже компьютера на столе нет! Это эдакий намёк тебе: "Знай своё место, собака!", "Не высовывайся, рудокоп магаданский!".
Что разрабатывать?
Основной источник работы - госзаказы и ОКРЫ. Конечный программист МК как правило даже не знает, что за комплекс разрабатывается в организации. Все платы называются "вычислительный модуль #N". Техническое Задание (ТЗ) для программиста МК под запретом. На рабочем компьютере нет доступа в сеть интернет. Монитор становится черным при запуске браузера. Утилиты можно устанавливать только через пароль руководителя отдела. Пароль для открытия диспетчера устройств, пароль, чтобы прописать путь в переменную Path, пароль на установку драйверов, пароль на удаление папок.
Любое электронное устройство, которое вы будете делать скорее всего можно будет назвать одним словом: переходник! Типичное IoT устройство это с одной стороны, например, датчик температуры на шине I2C, a c другой стороны WiFi модуль. Телематика - это тоже переходник: с CAN на LTE и т д. Всё, что я делал в российской электронике 10 лет подряд это переходники с одного интерфейса на другой интерфейс. Маршрутизаторы, модемы, телематика, СКУД(ы), аудиосистемы, IoT. Переходники. Переходники. Переходники.
Задач по программировать микроконтроллеры в России очень мало. На район с населением 300k человек будет всего 3-5 вакансий и конкурс 11 человек на место. Работу программиста микроконтроллера найти сложно.
При этом ВУЗы выпускают по 300 инженеров в год каждый. А в радиусе 20 км от вуза 30 вакансий. Туда возьмут отнюдь не самых способных выпускников, а тех кто согласится получать меньше всех корма.
Даже если Вы найдёте работу, то Вы сделаете всё за год, даже если будете писать всего лишь по 150 строчек кода в день. У вас буквально Flash память закончится за год. Прошивки пишутся быстро, особенно когда есть заготовки программных компонентов: MCAL, драйверы ASIC чипов, connectivity, sensitivity, computing, storage и control.
Как только Вы напишите прошивку, начальство станет предлагать Вам заняться всяческими смежными обязанностями: технический писатель, сисадмин, тестировщик, чертёжник, схемотехник, тополог, рабочий в производстве на участок ручной пайки поверхностного монтажа, курьер лишь бы хоть как-то оставить Вас в этой организации.
Если Вы будете отказываться, говоря, что хотите программировать микроконтроллеры дальше, то Вас станут изживать как проблемного сотрудника, перестанут давать новые задачи, назначат какую-н скучную рутину (например искать на рынке самые дешевые выводные резисторы), или придумают какую-нибудь провокацию (часто с участием женщин), спровоцируют на конфликт.
В этой профессии все пути тупиковые:
1—Если Вы будете бестолковым программистом, то Вас будут изживать из организации как безнадежного растяпу.
2—Если Вы будете очень толковым сотрудником, то Вас тоже будут изживать из организации ещё более интенсивнее, только уже как явного конкурента.
Да, программисты микроконтроллеров в России комерческому рынку нужны, но только как сезонные работники на одну прошивку (полгода-год), подобно тому как в Финляндии сезонно нанимают сборщиков клубники. А потом тебе снова метаться по собеседованиям, искать фриланс, out source.
Многие будут склонять тебя организовать ИП или работать удалённо как самозанятого. Это называется "предприниматель в спальне".
Поэтому в среднем программисты МК в России за 10 лет меняют работу от 7 до 15 раз!
Ещё программисты микроконтроллеров в НИИ часто работают в развёртывании так называемых АСУ ТП. Это разработка оборудования для управления котельными, электроподстанциями, оборудование для электро-щитков, оборудование для очистных канализационных сооружений. По сути оборудование для ЖКХ. Про это можно почитать тут.
Работать приходится в соответствующих не очень приятных местах на объектах. Как Карлсон лазить по крышам. На крышах, если что, нет уборных. Это крайне специфическая область, где сделки заключаются в основном через откаты. А до зарплат разработчиков доходят сущие крохи.
Вообще в России в профессии программист микроконтроллеров какой-то экзистенциальный тупик. Везде при обсуждении начала разработки любого электронного продукта обычно приходят к одному и тому же выводу, что Россия
a)--не сделает дешевле, чем в Китае и
b)--не сделает лучше, чем в США.
Поэтому работу программиста микроконтроллеров надо искать в компаниях, которые, как бы вне свободного рынка, которые получают государственный заказ от министерства промышленности и торговли (МинПромТорга).
Какие командировки у программистов микроконтроллеров?
Программистов микроконтроллеров обычно посылают в командировки в самые некомфортные места, которые себе только можно представить: настраивать СКУД в медные подземные шахты 300 метров под землей за полярным кругом (это где ночь длится полгода), настаивать оборудование в атомных электростанциях (ходить в свинцовых трусах), проверять телематику в открытых карьерах размером 4 на 8 км для добычи какого-то "недоступния" (глотать там пыль), перепрошивать электронные платы на подводных лодках (были случаи когда с инженером ушли в море и забыли его предупредить об этом), тестировать эхолоты на Белое море (с промежуточной остановкой на Соловецком ГУЛАГЕ), тестировать АФАР радары в зоне СВО.
Кстати, в профессии программист микроконтроллеров часто приходится отлаживать радио электронную аппаратуру (РЭА) прямо на улице, ибо GPS и дальнобойную радио связь в офисе ну ника не проверишь не отладишь. И, как правило, по закону подлости такая out-door отладка выпадает на декабрь-январь-февраль...Чтобы Вы понимали, за окном минус -29... -35 градусов по шкале Цельсия, сильный холодный леденящий ветер. Солнце слепит глаза. Даже на смартфоне не видно, что написано, шум от пролетающих фур на трассе. Приходится облачаться в ватники, двойные штаны, балаклаву, варежки, шапку-ушанку. На щеки и губы намазывать толстый слой крема от обледенения лица.
Поэтому такие работы у нас шутливо называется "выходы в открытый космос".
Да это просто романтика, господа! Только ответьте самому себе честно, Оно Вам надо?
Тестирование электронных плат кастрюлей
Особенность этой работы в том, что Вам постоянно будут нужны всяческие примочки, переходники, шлейфы, дефицитные импортные товары. Такие вещи можно купить только в спец магазинах через интернет по предзаказу и предоплате или на Aliexpress. Заказав примочку вам потом ждать два три месяца доставки. Потом ехать забирать эту посылку. Естественно работа в этот период ожидания примочки простаивает. При этом каждые два дня схемотехник с Вас спрашивает результат, которого Вы не можете дать без тех самых примочек, которые застряли где-то на таможне.
В одном российском НПЦ я был свидетелем одного очень оригинального способа тестировать электронные платы (PCB). Вот так это выглядит... Собирают электронную плату (размером с книжку), накрывают плату большой металлической кастрюлей вверх дном, подают питание на электронную плату под кастрюлей. В случае, когда изделие нормальное - ничего не происходит. В случае же, когда изделие бракованное внутри кастрюли раздается глухой хлопок и стук компонентов о стенки кастрюли. Иногда даже кастрюля подпрыгивает! А по ее периметру вспыхивает желтое кольцо. После снятия кастрюли выходит облачко дыма. Вот так в России порой тестируют Hi-Tech электронику.
Doсker по-русски
В российских военных НИИ\ППК\ФГУП, когда заканчивают разработку программы для электронной платы прибора, то чтобы была возможность потом вернуться к исправлению багов просто берут DeskTop на котором компилировались прошивки, монитор, клавиатуру и даже мышку, обманывают всё это в комок изолентой (установкой как в аэропортах для обмотки багажа) и относят комок на неотапливаемый склад. А программисту просто выдают другой шумный как пылесос DeskTop-компьютер. И у начальства там ещё язык поворачивается называть это хорошими практикам разработки!
Даже если в российских электронных компаниях попробовать внедрить такие западные практики как устраивать ежедневные 5-7ми минутные планерки, то сотрудники будут тупо стоять как истуканы с острова Пасхи и молчать.
Они привыкли неделями напролёт на работе ничего не делать, как какой-то трудовой резерв. Гонять чаи за пустыми разговорами. Каждый день они отчитываться не могут. Не привыкли... Либо просто будут не приходить на планерку так как нечего сказать. А нечего сказать, так как ничего вчера не делал.
Потом если взять ортодоксального российского программиста-микроконтроллеров и поместить его в западную модель программистского делопроизводства: ежедневные планерки, трэкер задач, сборка из скриптов, сервер сборки, статический анализ кода, инспекция программ, модульные тесты, снятие покрытие кода, спринты, Kanban. То выясниться, что российский программист-микроконтроллеров вообще не может решить ни одной задачи! По сути типичный российский программист микроконтроллеров не умеет вообще ничего делать, так как он просто не умеет программировать в том смысле, как это принято во всём цивилизованном просвещенном мире.
Для российского программиста микроконтроллеров единственный вариант по жизни, это сидеть промзоне своего военного НИИ, работать в кактус-соло режиме в какой-нибудь рафинированной GUI-IDE (типа IAR) со встроенными подсказками от Mickey-Mouse(а) и не высовываться!
Там же в промзоне чтобы компенсировать маленькую зарплату Вам будут говорить:
Да, боец, зарплата у тебя маленькая, зато твою работу покажут самому Президенту!
или
Этот прибор, который ты тоже делаешь, промчится на параде по самой Красной Площади!
Или вот чем нас воодушевляли:
Прибор который ты программируешь полетит прямиком на Луну!
а закончилось это вот этим
Это всё и будет, пожалуй, основной и единственный бонус, предмет гордости и бальзам на душу тебе как российскому программисту-микроконтроллеров. А если ты будешь роптать и жаловаться на трудность работы в таких условиях, то тебе скажет патрон что-то типа
Расскажи о своих программистских трудностях шахтерам на Донбасе...
Кстати про шахтёров... На промзоне каждый день будет обеденный перерыв. Однако то место, где это будет происходить ну никак нельзя назвать такими словами как "кафе" или "столовая". Судя по запахам шуму и освещению более подходящие для этого заведения словами являются "едальня" или "пищеблок".
В российских военных НИИ/НПО/ППК/ФГУП часто среди сотрудников также набирают массовки на всякого рода государственные мероприятия: премьеру какого-нибудь наитупейшего фильма (без обид), снятого на деньги из гос. бюджета, концерт певчивого под фанеру артиста, чей рейтинг держится на государственном аппарате искусственного поддержания жизни или государственные митинги в Лужниках или Олимпийском за пару сосисок и гречневую кашу. По разнорядке инженеров также отправляют на похороны каких - то местных чиновников. Инженеров просто ловят прямо на работе, вызывают из отпусков, набивают в автобусы и везут пополнять массовку. Если ты Боже упаси откажешься участвовать в этой показухе, то тебе там, как говорят, "создадут условия". В переводе на кухонный язык - назначат грязную скучную и тупую работу (искать самые дешевые выводные резисторы) на полгода вперед пока ты окончательно не потеряешь рассудок.
При этом в профессии программист-микроконтроллеров очень трудно убедить организацию купить инструменты для эффективной работы. Что-нибудь совершенно по мелочи, что-то ну совершенно копеечное: блок питания, переходник USB-UART, штангенциркуль, шлейф, Android приложение для отладки uBlox чипа c GNSS. Надо заполнить кучу формуляров. Написать простыню для обоснования и 80% получить отказ. Или в 20% получить разрешение, а потом ждать два-три месяца пока согласуют и купят. А если и купят, то как правило оказывается, что купили не совсем то, что надо. В результате ты все примочки, как правило, покупаешь за деньги из своего семейного бюджета.
Про профессиональные традиции
Никаких традиций в профессии программист-микроконтроллеров в РФ исторически за 50 лет так и не сложилось. Не получилось... Тут речь идет не о тех традициях, чтобы дать новичку выпить стакан морской забортной воды и поцеловать качающийся молоток. Вовсе нет! Нет традиций в смысле того, что нет хороших практик разработки прошивок для микроконтроллеров! Например, нет доверенной покрытой тестами кодовой базы на всю страну (аналога европейскому AUTOSAR или Zephyr Project). То есть нет тех самых кирпичей из которых можно было бы гарантированно собирать работающее "программное здание". Нет никакой общей культуры разработки системного ПО. Нет системного подхода. Нет преемственности в делах.
Разработка всюду похоже на анархию, Броуновское движение. Зачастую тебе придется работать даже без технического задания! Задачи могут поставить так:
--Оживить плату!
--Подружить микроконтроллер и айфон!
--Подружить платы!
--УУ ВайФай!
Понимай эту ахинею как хочешь... Нет общей терминологии. Везде свой внутренний нецензурный фольклор.
Кстати про матерщину.
В российских инженерных коллективах очень рьяно циркулирует просто отборнейшая матерщина. Я по началу никак не мог понять:
Как же так получилось? Ведь все прошли через институты, университеты. Профессоры, доценты и аспиранты не сквернословили, а тут на работе какой-то криминальный фольклор. Что происходит? Почему?
Потом стал познавать историю предприятия и понял откуда все пошло... Дело в том, что вся российская инженерная школа сформировалась в 193х годах. Тогда всех инженеров, авиаторов, чтобы не платить им зарплату, Иосиф Джугашвили загнал в лагерные шарашки и ГУЛАГИ. Через этот кошмар прошли Поликарпов Николай Николаевич, Туполев Андрей Николаевич, Сергей Павлович Королев, Глушко Валентин Петрович и миллионы других более мелких инженеров. В этих местах "не столь отдаленных" советские инженеры много лет жили бок о обок с матёрыми зэкам, уголовниками и, естественно, инженеры набрались от них жаргона. Спустя 15-20 лет в середине 195x инженеров выпустили из тюрем, каторг, рудников и колоний "За отсутствие состава преступления" и они пошли работать во всяческие НИИ, КБ и НПО. A тюремные привычки и нравы-то никуда ведь не исчезли, а просто плавно перешли в здания без решёток. Так и продолжается до сих пор. Кликухи, матерщина, издёвки и дедовщина всё это норма жизни в современных НИИ, НПЦ и ФГУП.
В современной российской инженерной молве чрезмерно много жаргона и сквернословия. Это одна из бед. Русские забыли настоящий красивый инженерный язык времён последних инженеров российской империи Владимира Шухова, Косьмы Зворыкина, Игоря Сикорского и прочих.
По факту сейчас у вас только два варианта. Вам придётся в повседневном общении на работе либо самим регулярно применять грязную и пошлую матерщину, как и все, либо лояльно и толерантно относиться к матерщине вокруг Вас. Тут другого, простите, просто не дано...
Более того, в российских инженерных кругах, чем более жёсткую и суровую человек употребляет матерщину, тем выше авторитет этого человека! Да... Техническая же экспертиза на этом фоне уходит куда-то на второй план. Матерщина на работе воспринимается даже как проявление некоторого рода интеллекта, так как те, кто не сквернословят выглядят как овощи. Просьба, друг, относиться к этому с пониманием...
Патроны называет коллег не то "бойцами", не то "боевиками". Понимаете, насколько это криминальная область деятельности - программирование-микроконтроллеров в РФ.
Сильная зависимость от внешних факторов
Есть некоторая нездоровая специфика программирования МК в РФ. Свою оригинальную электронику в России делать отказались еще в конце 196х. Был принят гос. план тотального копирования западных IBM(ов), Intel и Z80 процессоров. В результате Россия стала полным акцептором IT технологий. Сегодня у России нет своего дешевого процессорного RISC/MIPS/PowerPC ядра, нет своего компилятора для известных ядер ARM, PowerPC, RISC-V. У РФ нет даже своего текстового редактора! Благо есть открытый софт (Linux и GCC), которым и пользуются российские компании. Страна полностью зависит от импорта микропроцессоров и ToolChain(а) для микропроцессоров. Микроконтроллеры активно покупают в Норвегии(nRF5x) Италии(STM8), Франции(STM32), США(TI, PIC), Китае(esp32, Artery, GigaDevice), Нидерландах (LPCXXXX), Канаде(BCXXX), Швейцарии(STM32). Toolchain покупают у Швеции (IAR), Германии(Keil) и США(GHS).
Будучи программистом микроконтроллеров вы будете максимально сильно зависеть от внешних факторов и флуктуаций. Вы будете работать в условиях отсутствия суверенитета.
1—Микроконтроллер, который Вы программируете могут включить в санкционный список.
2—Datasheet на новый чип вам могут отказаться прислать из-за NDA
3—Вам могут аннулировать лицензию на компилятор GHS.
Всё это на западе называется модным выражением "закрыть маршрут разработки" для неугодных стран и компаний.
В США ситуация диаметрально наоборот. Там не то, что есть полный цикл IT продуктов. Дак там ещё есть каждый IT продукт в нескольких экземплярах, т.е. от нескольких вендоров. Микропроцессоры AMD, Intel, TI, Microchip. Софт операционных систем от MAC, Windows, BSD. Компиляторы TI, GHS. И всеми любимый текстовый редактор VS Code от Microsoft!
Про Санкции и Эмбагро
При работе в России программистом микроконтроллером тебе прежде всего придется выучить такие слова как: импорт, NDA, vendor locking, санкции и эмбарго.
Дело в том что Россия - страна санкционная. И это теперь на века... В российской организации могут запросто опрометчиво решиться начать разработку какого-нибудь электронского поделия, которое можно реализовать только на одном единственном импортном чипе из просвещенного ЕвроСоюза или США. Что-типа AD9208. А Vendor этого чипа например Analog Devices или TI наложит эмбарго либо сразу, либо потом и не будет присылать вам полный datasheet как и сами чипы, техподдержку, так как РФ, по их мнению, является санкционной территорией. И в результате ты, как программист микроконтроллеров тут вообще ничего не сможешь с этим сделать!... Такая история у меня лично была уже дважды (чип PM6766 для питание серваков) и модуль ZED_F9P (высокоточная GNSS-RTK навигация).
Даже если российская компания вдруг задумывает сделать примерно современное электронное устройство с BGA корпусами, PCB антеннами, то как правило это заканчивается тем, что схемотехник(и) сталкиваются с технологическими проблемами, первая ревизия плат вообще не работает из-за неправильного выбора пинов на микроконтроллере (схемотехнические ошибки), компоненты припаяны не той ориентацией, припаяны не те кварцы и в итоге экземпляры электронных плат даже не доходят до стола программиста-микроконтроллеров.
В РФ часто начинают проектировать электронную плату, а потом выясняется что нет возможности купить нужные микросхемы, разъёмы, светодиоды и прочее. Просто схемотехнику живут в вымышленном мире эльфов, где думают что, то, что они нашли в интернете по их желанию тут же им припаяют. В итоге разработка уходит в штопор из-за того что банально нет возможности собрать до конца художество схемотехников.
Уровень современной российской схемотехнической школы сейчас настолько низок, что о программировании и говорить порой даже не приходится. На предприятиях кроме готовых отладочных плат от вендора зачастую просто нечего программировать. Только, внимание, четвёртая-пятая ревизия российских PCB обычно лишена детских болезней. Пятая! Да, вот так, господа...
В РФ по-настоящему передовые электронные разработки часто попросту не доживают до серийного производства банально из-за очередного эмбарго. Я был свидетелем как один мой коллега в российской организации переписывал прошивку с 32-битного микроконтроллера на 8-битный микроконтроллер. Вот такой, товарищи, "прогресс"! Потом видимо будут переносить функционал c 8-битников на электро-релейные командо-аппараты. Потом на шестеренчато-кулачковые механизмы. Так что можете смело вместо новых языков программирования типа Rust(а) начинать учиться чертить детали машин. Причем лучше сразу на бумаге! Нас тут, по ходу, снова ждёт паровой век! Аж дух захватывает...
Российские компании не хотят ничего выдумывать. Боятся. Предпочитают копировать то, что уже есть на Западе, без какого бы то ни было оригинального "видения" продукта и товарной политики. Копируют буквально заклёпка в заклёпку, шильдик в шильдик. Тем более, что корни у этого процесса очень-очень давние. Например в СССР скопировали американский бомбардировщик B-29 -> и получился Ty-4. Скопировали атомную бомбу Fat Man - в советскую РДС-1. Больше примеров можно увидеть тут.
https://docs.google.com/spreadsheets/d/1qN1byQ0WxMioVbxBkGvKu5PQMvwMiCRe_2rgx16G3Gw/edit#gid=0
Вот как раз поэтому едва ли в РФ получится участвовать в какой-либо уникальной прорывной разработке на микроконтроллерах. Даже если ты виртуоз в программировании микроконтроллеров, то по настоящему грандиозные проекты в РФ скорее всего всё равно просто не удастся сделать из-за очередного эмбарго и санкций. А между тем проекты реальных гаджетов американских школьников с Kickstarter(а) или CrowdSupply вызывают куда больше восхищения и трепета чем то, что пытаются делать сорокалетние мужики в электронных компаниях РФ со своим якобы "громадным" электронным опытом.
(см Software Defined Radio руками шестнадцатилетнего подростка https://habr.com/ru/articles/330052/)
Издёвка судьбы ещё и в том, что существование российского ВПК не вписывается в карту реальности (картину мироздания) Западной политики. Понимаете?
Дядюшке Сэму это всё не нужно!
США и ЕС лелеят мечту, спят в видят Россию нищей грязной раздробленной сырьевой территорией (даже не страной) с мизерным необразованным, спившимся, укуренным, суеверным населением без письменности под внешним управлением колониальной администрации... Ну вот как-то так...
Поэтому все западные поставщики микросхем будут постоянно чинить препятствия и козни Вашей российской электронной организации. Проявляется это по-разному. Они накладывают эмбарго на продажу литографов ASML. Запрещают продавать в РФ лицензию на компиляторы (например GHS). Навязывают vendor locking программы для разработки: (это IAR, Keil, Code Composer Studio), которые не позволяют делать чтобы то ни было без мышки. Продают мелочёвку по завышенным ценам. Перекрывают цепочки поставок. Запрещают скачивать документацию и утилиты для работы с их сайтов и прочее. Перекрывают доступ к их сайтам.
Отказывают Вам в посещении профильных мастер-классов в Европе. И даже умудряются, не много не мало, протолкнуть на высокие руководящие должности российских госкорпораций своих людей для саботажа сверху, в тылу неприятеля! Вот так, господа...
В одной российской организации, я был свидетелем как к нам в офис регулярно приходил американский под-поручик от Texas Instruments и буквально диктовал нашему начальнику отдела, какие микросхемы следует закладывать в проект российского прибора. Потом эти микросхемы в самом деле оказывались в финальном приборе. А спустя несколько месяцев эта же Texas Instruments объявила Эмбарго на те микросхемы, что сама же приказала поставить. Вот так, просто кинули...
И Вы тут как рядовой программист-микроконтроллеров ну вообще ничего не сможете с этим сделать...
Поэтому многие настоящие разработки военной электроники в России происходят как бы нелегально, незаконно, глубоко под землёй. В минус первых, минус вторых этажах крупных промзон и университетов. Или вовсе в бункерах и казематах. Естественно, десятки работников-электронщиков там фактически никогда не видят белого света. Также внутри банально трудно дышать. Вот оно Вам надо?
Восемьдесят процентов того, что бы сделаете на работе программист-микроконтроллеров пойдет прахом. Проект задвинут в тумбочку как какое-нибудь крамольное советское кино. Основные причины это Санкции и Эмборго на элементную базу. Потом отмена выставки. Ошибки в схемотехнике. Дизайн PCB платы не прошел электромагнитную совместимость (EMC). Брак производства. Трагедия на испытаниях. Отсутствие потребителей продукта. Уход инвесторов. Потом, смена руководства отдела. Новый начальник демонстративно зарубит все проекты прошлого руководителя. В общем 80-90% вероятность, что вся разработка не дойдет до серийного производства и всё как обычно накроется медным тазом.
Программист-микроконтроллеров это отличная профессия для тех кто хочет работать "в тумбочку" и "под сукно".
К слову, именно поэтому в Ваших же интересах писать код прошивок максимально модульным, чтобы можно было потом пере использовать программные компоненты в других проектах.
У программистов микроконтроллеров начальник-схемотехник.
Обычно программист микроконтроллеров работает в отделах, которые по советских называются: "отдел разработки радио электронной аппаратуры" (РЭА). Поэтому, как следует из названия, начальник там - бывший схемотехник. Всё начальство программистов микроконтроллеров в российских организациях в пяти случаях из шести - это в прошлом схемотехники, чертежники или вовсе конструкторы механики. О программировании они знать ничего не хотят из принципа, они из тех кто просто ненавидит программировать еще с института. Начальник-схемотехник даже программирование называет "программизмом", прошивание называет "прожиганием", микроконтроллер называет словом "мозги", а самих программистов-микроконтроллеров "софтописцами". Это как?
--Схемотехник тебе как начинающему программисту-микроконтроллеров никогда не подскажет, что собирать из Makefile(лов) эффективнее, чем сборка из-под GUI-IDE.
--Схемотехник тебе не посоветует настроить GIT.
--Схемотехник не скажет, что отладка из UART-CLI эффективнее чем отладка через SWD/JTAG.
--Схемотехник не порекомендует делать модульные тесты кода.
--Схемотехник тебе не посоветует запустить сервер сборки Jenkins для контроля сборок.
--Схемотехник не научит тебя делать code coverage.
--Начальник схемотехник никогда не порекомендует тебе воспользоваться утилитой grep.
От себя могу добавить, что после своего регионального политеха за первые три года своей карьеры работая с начальником-схемотехником, я не научился у него, ровным счетом, абсолютно ничему IT(шному). Учиться у схемотехника программированию невозможно по определению. Если ты попал в отдел РЭА, то это, друг, финал твоей карьере как программиста. Своего рода, конечная остановка в профессиональном развитии.
Справедливости ради, стоит всё-таки упомянуть, что начальник-схемотехник в лучшем случае может научить тебя разве-что некоторым трюкам ручной пайки. Например с применением термо-фена и оранжевой каптоновой ленты, о существовании которой, кстати, в среднем 7 из 8 схемотехников даже не догадываются. Вот, пожалуй и всё...
Причем будь готов к всяческим странностям в таких отделах РЭА. Вот буквально несколько примеров из жизни:
1--однажды в отделе РЭА ко мне подошел начальник-схемотехник и попросил, чтобы я составил, внимание:
Документ-требования к транспортировке программного обеспечения (ПО) железнодорожными видами транспорта.
2--Или уже в другой организации ко мне приблизился мой непосредственный начальник (в прошлом чертёжник прямоугольных корпусов) и устно сказал:
Напиши требования и методику проверки работы твоего программного обеспечения (ПО) по температурным диапазонам ПО.
От же
Напиши мне IP-код зашиты от пыли и песка для твоего программного обеспечения.
3--Или вот начальник схемотехник попросил меня перед новой разработкой:
—Предоставь, пожалуйста, эскизный проект программного обеспечения для микроконтроллера.
4--В конце разработки начальник схемотехник попросил меня распечатать *.hex файл с прошивкой для микроконтроллера, чтобы оформить архив на разработку электронного прибора. Распечатать!..
Интересно Back-End программистов Web сайтов, GameDev разработчиков или программистов мобильных приложений под Android/iOS менеджеры тоже о таком просят???
5--Однажды я был свидетелем, как начальник-схемотехник для разработки прошивки по ошибке нанял python программиста!
Типичная российская электронная разработка выглядит примерно так. Начальник отдела открывает Aliexpress и покупает там не глядя какой-то случайный дикий ПЛК, вручает программисту микроконтроллеров этот ПЛК и говорит: "оживи устройство". При этом на ПЛК нет абсолютно никакой документации, продавец на Aliexpress не отвечает на сообщения c вопросами прислать pdf(ку). И всё, что остаётся это взлом хакинг и реверс инжиниринг этого азиатского прибора.
А вот это, господа, коллекция золотых перлов начальников-схемотехников:
1--Тестировщик ПО не нужен. Вы о чём вообще? Если программист хороший, то и код он пишет без ошибок!
2--Оживить плату!
3--Подружить платы!
4--Программистам-микроконтроллеров не нужна схемотехника. Пусть код пишут.
5--SVN/GIT не нужен так как у нас только один программист-микроконтроллеров.
6--Зачем ты сделал для разных микроконтроллеров две отдельные *.hex прошивки? Сделай один универсальный *.hex файл сразу для всех электронных плат!
7—Не нужны нам программисты-микроконтроллеров! Бот ChatGPT сам составит нам *.hex файл с прошивкой!
8—Устройство должно отвечать по CAN за ноль микросекунд.
9--Какой ещё DevOps? Не морочьте мне голову!
10--Сделайте Мне хорошо!
Вот так и живём, господа... Твоя задача - телепатировать, угадать, что хочет начальник-схемотехник и угодить ему, как женщине, ибо мысли излагать на бумаге (ТЗ) он все равно не хочет и не будет! Гордость и предубеждения не позволяют...
При этом начильник-схемотехник считает, что любую прошивку можно написать за один, ну максимум за 2 дня. Схемотехник убежден, что код даже сохранять не надо. Что любую прошивку можно написать вообще за один присест.
Поэтому в разработке приборов на микроконтроллерах постоянная конфронтация между программистами и схемотехниками. В провалах схемотехники обвиняют программистов, a программисты - схемотехников.
Какую бы хорошую прошивку бы ты не написал, схемотехники непременно назовут её "галимой прошивкой". И как бы ни старался схемотехник, его электронную плату программисты назовут "мертворожденная PCB".
Это просто уже классика жанра и норма жизни, к которой все давно привыкли.
Код прошивки абсолютно никого не интересует.
В программировании микроконтроллеров большинство русских фирм даже не заботятся об исходном коде как таковом вообще. Для их процессов внутри организации кода как будто бы и не существует вовсе! О коде не говорят. Код не изучают, код не анализируют, исходный код не тестируют, не улучшают, не упрощают. А таких слов как "архитектура ПО", MiddleWare и DevOps стены российских электронных организаций никогда в помине и не слышали!
Интерес представляет только физический прибор. Поэтому в большом почёте схемотехники и конструкторы (чертёжники). Дело в том, что микросхемы обычно маленькие габаритами 4x4 мм, а начальство сидит ^высоко^ и не замечает каких-то там микросхем-лилипутов. Это ниже их достоинства. Начальники лишь электронные платы видели пару раз в году. Поэтому конструкторов и схемотехников на промзонах ценят существенно выше, чем каких-то там программистов-микроконтроллеров. Руководство буквально души не чает в схемотехниках. Делает схемотехников своей правой рукой. Начальство водит схемотехников на все высокие совещания отправляет в командировки в престижные страны.
Также в промзонах высоко ценят FPGA разработчиков. Это по сути схемотехники цифровых электрических цепей внутри SoC(ов). Это проявляется в высоких зарплатах у ПЛИС схемотехников и позволения им любого времени прихода на работу. Видел даже как FPGA разработчику оплатили хирургическую операцию в частной клинике! Вот так...
А программистов микроконтроллеров напротив считают бездельниками. Если нужно разработка ПО, то нанимают только одного единственного программиста-микроконтроллеров. Никому там и в голову не приходит, что работы по написанию кода прошивки на самом деле минимум на 7 программистов! При этом Си-исходники можно вообще хранить в открытом доступе и это никого в общем-то тоже не волнует. По факту исходники микроконтроллера никого кроме 1-го единственного разработчика не интересуют. В одной российской организации я видел как программист микроконтроллеров называл Си-функции именами литературных персонажей и это никого абсолютно не волновало, так как кроме него с этим исходным текстом программы MCU никто не работает. А он так просто хотел стать незаменимым сотрудником. И, как правило, один человек делает прошивку для одной электронной платы.
Мракобесие, Обскурантизм и Мартышкина Бюрократия (или "Нельзя просто так пойти и купить овцу!")
С другой стороны в некоторых российских электронных организациях таки есть внимание в коду. Это проявляется в наборе подозрительных извращённых требований категории "полная блажь". Вот буквально несколько реальных примеров из жизни. Диктатура абсурда. Парад нелепости.
1—Строгие правила расставления отступов к коде и вообще искусственно выдуманное форматирование кода, которое даже опциями clang-format или GNU-indent выставить нереально. Только ручное расставление отступов!
2—Строгие правила оформления шапки текста перед каждой функцией. Не дай бог поставишь лишний пробел!
3—Строгие правила оформления текста в GIT комментариях к коммитам. Что, зачем и почему + код тикета.
4--Писать текстовые комментарии к каждой строчке Си-кода.
5--Строгий запрет на использование битовых полей в языке программирования Си.
6--Строжайший запрет на использование перечислений (enum) в языке программирования Си.
7— Запрет на использование стандартных типов данных из файлов <stdint.h> <stdbool.h> (bool, uint32_t, int8_t и проч.)
8--Строжайший запрет на использование объединений в Си (union).
9—Собирать код только мышкой из-под GUI(ни)-IDE (IAR или KEIL) и никаких там скриптов сборки!
10—Запрет установки программ, запрет открытия диспетчера устройств, запрет открытия диспетчера задач, запрет прописывания переменной PATH на локальных PC.
11-- предпоследняя строка исходного файла должна содержать комментарий "end of file" (см. шаблон), первая строка файла должна содержать комментарий "start of file"
12 -- Настройки компоновщика хранить прямо в папке с проектом. И так для каждого проекта с одним и тем же микроконтроллером.
13-- Использование кода сторонних библиотек запрещено! Никакого CMSIS, FatFs, FreeRTOS, HAL от официального производителя микроконтроллера! Любое Third Party запрещено!
14-- Все параметры функций должны быть перечислены "в столбик".
15-- каждая конфигурационная константа должна иметь комментарий с "Valid values", в котором описано множество возможных значений данной константы. Перечисления (enum) же запрещены, поэтому надо выкручиваться.
16-- Для всех объявлений глобальных функций в h-файле обязательно ключевое слово extern! Не важно что и без него работает.
17-- Порядок объявления static функций должен совпадать с порядком определения функций
18-- Комментарии должны начинаться с //! Никак иначе!
19— Строжайший запрет на использование функций из <math.h> [sin() cos() log10() fabs() и т. п.]ъ!
Сами понимаете, что всё (с 1 по 19) это просто требования ради требований. Чтобы каждый день показывать черни, кто тут хозяин! Думаю не надо пояснять, что такая мартышкина бюрократия лишь только тормозит достижение реального функционального результата по разработке System Software и действует только на радость нашим геополитическим врагам.
При этом, напомню, что в таких щепетильно "требовательных" организациях, как правило, не принято покрывать код модульными тестами, в прошивках нет NVRAM, в прошивках отсутствует UART-CLI для отладки функционала, нет скриптов сборки, нет и сервера сборки, никакого даже в Jenkins, в прошивках нет загрузчика и многого-многого того, что, по здравому смыслу вообще-то должно, быть сделано как раз в первую очередь! Понимаете?
Порой всё это законотворчество (пункты 1-19) выглядит, как соблюдать правила хирургической стерильности, внимание.... в конюшне! Да.. Именно так...
Или это обыкновенная "диверсия сверху"? Тогда всё предельно логично и понятно. Да... И такое, к сожалению, бывает... Вот даже текст есть про способы подрывной деятельности.
Я лично абсолютно ничего не имею против требований к коду. Это даже здорово, что есть стабильная работа вокруг всего этого цирка. Однако эти требования обязаны сопровождаться ясной и прозрачной аргументацией для чего их так рьяно нагнетают. Правда в том, что каждое требование к коду сдвигает срок сдачи проекта на 10-15%. Когда в компании 463 правила оформления кода, то время разработки увеличивается в 46,3 раз. Понимаете?
Скажите мне, смог бы солдат Курчатов Игорь Васильевич сделать атомную бомбу с нуля за 4 года с такой бюрократией? Думаю ответ и так всем понятен...
В России Две Школы Программирования Микроконтроллеров
В России из-за больших расстояний и слабой коммуникации исторически сформировалось две абсолютно различные, независимые и непримиримые школы программирования-микроконтроллеров.
Можно условно их назвать Питерская школа и Московская школа. Что, к слову, вполне соответствует географии.
--Питерская школа это сборка из самописных скриптов Make/CMake, отладка через UART-CLI, модульные тесты внутри прошивки, текстовые протоколы, DevOps (в Jenkins), командная работа (парное программирование).
--Московская школа это сборка из-под GUI-IDE, отладка только через JTAG, внешние тесты на PC, бинарные протоколы, solo-разработка.
Я прошел через обе эти школы и могу сказать, что возникают серьезные конфликты, когда в одном коллективе оказываются представители двух разных школ, и тут надо искать компромиссы, вариантов нет. Это как извечные споры между приверженцами Windows или Linux.
Боже упаси Вас на собеседовании в Москве хоть что-то упомянуть из практик Питерской школы. Работу точно не получишь. И наоборот в Питере не любят прогеров придерживающихся московской школы.
К сожалению более примитивная московская школа сейчас побеждает. Да, это факт. Главным образом это происходит из-за того, что в Москве просто больше людей и больше работы. Поэтому у московской школы программирования МК оказывается больше лоялистов.
Невозможность Профессиональной Эмиграции
В профессии программист микроконтроллеров насколько бы упорно и усердно Вы не работали, то Вам всё равно не светит профессиональная миграция в развитые страны: США, Австралию, Англию, Новую-Зеландию и т.п.
Дело в том что российская, с позволения сказать, школа программирования микроконтроллеров настолько, мягко говоря, самобытная, что западные коллеги [начиная с восточной Европы (Польша, Финляндия, Эстония) и Балкан (Словения, Хорватия)] Вас просто не поймут и не признают, как Embedded/Firmware программиста. Там другие стандарты, другие методы работы. По-другому устроено делопроизводство. Там всё по-другому. На западе не видели российских микроконтроллеров, российских электронных товаров и справедливо там считают, что в России никто и ничего в этой теме просто не умеет. Сколько бы российского опыта у Вас ни было 5, 10, 15 лет. Всё одно. Лучше с этим сидеть дома.
Российская школа программирования микроконтроллеров ушла не туда. Вместо развития принципов TDD и DevOps, как на западе в российской школе программирования микроконтроллеров больший упор сделали на муштру. Писать в конце файла комментарий словами: "это конец файла", в конце каждой функции писать комментарий: "это конец функции", перед #include писать комментарий: "это заголовочный файл" и так 463 правила...
Даже гипотетически оказавшись в западной компании, с российским образованием и российским микроконтроллерным опытом Вы не сможете там решить ни одной задачи. Западу как цивилизации проще, привычнее, удобнее и понятнее нанять программиста-индуса или программиста-иранца, чем российского Кулибина, Черепанова или Ползунова.
Программисты микроконтроллеров - странные люди.
Как правило на один проект сажают одного человека. Командной работы нет в принципе. Поэтому программистами микроконтроллеров работают, как правило, только ортодоксальные интроверты, мизантропы и социопаты. Да простят меня коллеги...В связи с этим программисты микроконтроллеров как правило нелюдимые, нервные, дикие, агрессивные и вспыльчивые. Общаться с ними некомфортно, сложно, а порой и вовсе опасно. У программистов МК напрочь отсутствуют такие понятие как Soft Skills и эмоциональный интеллект. И с годами ситуация только ухудшается. Программисты MK начинают отращивать себе длинные волосы как у женщин, плести косички, завивать кудри, делать себе наколки, пирсинги и тоннели в ушах. Потом программисты-микроконтроллеров превращаются в нечто, что окружающим приходится пристально вслушиваться говорит человек глаголы на xxx(ла) или xxx(л), чтобы понять перед тобой мужчина или женщина.
Или наоборот программисты микроконтроллеров бреются налысо аж череп блестит как шар для боулинга. Один знакомый программист МК в РФ ходит круглый год под огромным разноцветным зонтиком (даже летом в отличную погоду), другой знакомый программист МК утром на работе, когда заваривает себе кофе кладет в стакан сверху три ледяных кубика! Другой ест мороженое держа его за макушку палочкой вверх.
Другой программист-микроконтроллеров наливает себе в офисе чай использую такую химическую посуду как конические колбы, химический стакан. Наливает заварку через воронку, придерживая фильтр тигельными щипцами. Сам чай пьет из испарительной чаши.
Третий вместо пенала для ручки и карандаша использует химическую пробирку, заткнутую пробкой от вина. Четвертый программист MCU работает перед монитором в офисе в зимней куртке! Я даже видел в России одного программиста-микроконтроллеров гея! Он ходил на работу в женской шелковой одежде в цветочек. При всех ярко-красной помадой красил себе губы перед зеркалом в open-scace и накладывал на обе щеки пудру! Вот так...
И это только то, что можно увидеть на работе. Полагаю, что в обычной жизни программисты микроконтроллеров ещё скорость своего автомобиля определяют трубкой Пито, место на парковке во дворе ищут в шлеме дополненной реальности, а в лифте поднимаются с надетой кислородной маской.
Вот как-то так...
Все в ХакСпейсы! (или ячейка друзей электроники)
Ещё периодически по субботам программисты микроконтроллеров кристаллизируются в так называемых "хакспейсах". Когда я туда впервые пришёл и спросил как называется это сообщество мне ответили, что это, внимание, "ячейка друзей электроники!". Это, как правило, арендованное непонятно кем офисное помещение на окраине города без особых удобств и с "бабушкиным ремонтом". Часто подвальное. Там внутри хакспейса они называют друг друга странными кликухами: Кот, Крот, Крей, Енот и т.п..
Там появляются такие напомаженные "хакеры". Например у одного типа там ко всем USB-Flash(кам) синей изолентой примотана пороховая петарда (Корсар-4). Это, видимо, чтобы всегда можно было оперативно отформатировать данные. Для антуража там есть стол на котором лежит включенный паяльник, которым никто не пользуется.
В HackSpace(ах) они в основном занимаются, внимание, пьянством! Еще смотрят артхаус фильмы. Потом поздно ночью выходят на коллективную уличную прогулку по дворам. Причем удивляет не то, что они выходят на прогулку именно ночью, а то, что они при этом ходят строем по 4-6 человек как какая-то ЧВК и ещё курят вэйпинг. Эх... Всё это очень похоже на нездоровую секту...
В общем, программисты-микроконтроллеров - это очень странные люди. Порой думается, что они просто не от мира сего...
Соло работа. Мало общения на работе.
Обыкновенна ситуация, когда программист микроконтроллеров в принципе ни с кем не разговаривает по проекту на работе по полгода и более так как это чисто соло работа. На расстоянии вытянутой руки сидит другой такой же соло-программист микроконтроллеров. Он пишет прошивку для другой электронное платы, которая на 70% совпадает по аппаратной начинке.
Каждый пишет на Си свою бажную версию FIFO, циклического буфера, функцию swap, CRC8, CRC16, CRC24, CRC32, SHA256, парcеры базовых типов данных из строчек, NVRAM, allocator, цифрового фильтра, DFT, FFT, загрузчика, reverse_bytes, Reed Solomon/AES26/Base64/RLE encode/decode, шрифты для графических экранчиков, парсеры бинарных протоколов UBX, CSV, NMEA, RTCM, генераторы QR кодов и прочее, и прочее зачастую даже без юнит тестов.
Понимаете, они так часто пере изобретают велосипеды, что им и модульные тесты писать просто некогда!
Программисты MCU в России не умеют работать в команде. Да это факт... Три раза был свидетелем, как программисту МК предлагали напарника, помощника, а тот говорил:
Ой не надо. Он мне в спину дышать будет. Он мне тут всю экосистему в программе поменяет....
А по факту проблема в том, что без TDD (Test Driven Development) совместная разработка реально не работает. Вот и получается, что есть только два выхода - делать все по одиночке или делать вместе по TDD. Только до осознания пользы TDD в embedded России пилить и пилить ещё лет 40-50. Вот и остается всё делать по одиночке в кактус-solo режиме.
Промышленная разработка firmware (прошивок) в России похожа на советские кружки судо моделирования или радиолюбителей. Каждый делает что-то как будто для себя и радуется, если получается. Никакой командной работы нет в помине! Нет общей информации. Прошлый опыт быстро обнуляется. Экспертиза не накапливается. Каждый раз из проекта в проект они героически решают одни и те же ошибки. Ещё у программистов МК нет отдельных тестировщиков как класса.
Поймите у программистов микроконтроллеров нет даже менеджера пакетов, как это повсеместно, например, в разработке на Python. В программировании MCU даже нет аналога игровых движков как в GameDev(е). Поэтому каждый раз, в каждом новом микроконтроллерном проекте прошивка проходит путь эволюции от одноклеточной амёбы до циклопического динозавра.
В российских электронных организациях только одна планерка в год. На ней коллеги решают, что подарить начальнику отдела в день рождения.
В добавок к этому каждый собирает артефакты по-своему. Первый никогда ничего не знал кроме IDE IAR, второй точно такой же только в IDE Keil, третий ничего не знает кроме AtilocTrueStudio, 4тый собирает через GCC+Eclipse ARM plugins, 5тый работает в GCC + Make + OpenOCD, 6ой в GCC+СMake+ST-LINK_gdbserver, седьмой GCC+Ninjia+VSCode, 8й программирует в STMCubeIDE, 9тый в Code Comрoser Studio, 10тый зачем-то собирает прошивки для STM32 из-под снобского Zephyr Project (Yaml / West /DevTree /KConfig / CMake /Ninja /GCC/VScode/VisualGDB). Другие собирают Ubuntu, С++20, Meson, GDB. В общем полная анархия.
Программисты микроконтроллеров - они как сантехники, каждый ходит со своей корзиной с инструментами.
Повторяемость кода достигает количества программистов в организации умноженная на 100%. Обычно это 550%...750%. Всё максимально неэффективно. Их сорцы никто не контролирует, их код не инспектируют, не тестируют, не пере используют. Большинство разработчиков даже юнит тестов не делают. Они даже слов таких как "юнит-тест" в свои 43 года ни разу не слышали! В результате во всех микроконтроллерных программах как правило дичайший хаос (функции по 5k строк, магические циферки на каждой строчке, в каждом файле доступ в регистры) жесткая привязка к FreeRTOS, и этого даже никто не заметит и не остановит! Это особенность российско-татарско-сибирской программистской культуры ведения R&D.
При этом среди российских программистов МК очень большой разброс по способностям. Знания Умения Навыки (ЗУН) 3х разработчиков с 10ю годами опыта могут отличатся в 10, 100 и даже 1000 раз! Когда все работают по одиночке в своих норах этого не заметно. Но как только появляется работа над общей кодовой базой, то вскоре выясняется кто тянет всю команду на дно.
Если ты программист микроконтроллеров, то ты будешь разве-что регулярно согласовывать детали для стендов в которые будут пристегиваться электронные платы, которые ты программируешь. Вот типа таких.
https://habr.com/ru/post/709932/
Поэтому твоими основными коллегами для общения будут слесаря, токари и фрезеровщики.
В Программировании Микроконтроллеров Нет Людей-Легенд
В программировании микроконтроллеров нет людей легенд, как это присутствует в GameDev (Джон Кармак), Mobile (Ян Борисович Кум), Compilers (Джеймс Гослинг), DeskTop ( Ричардом Броди) или Web (Марк Цукерберг).
В Embedded отсутствуют глобально признанные авторитеты разработки внутреннего программного обеспечения и, как следствие, нет знаменитости в этой, с позволения сказать, "индустрии".
В результате, нет примеров и ориентиров того как надо делать. Нет историй успеха в программировании микроконтроллеров.
Никто и никогда Вас не будет чествовать в этой чудо профессии программист- микроконтроллеров. Зато упрекать за то, что вы не телепатировали в пожеланиях к прошивке вас будут регулярно. Тщеславным людям в Embedded разработке делать абсолютно нечего!
Никто в детстве не мечтает стать программистом микроконтроллеров. Да это факт. Я и сам узнал, что есть такая работа только на 4м курсе института в свои 23 года. Как правило, каждый программист микроконтроллеров попал в эту профессию случайно. Учился на инженера-электроника на приборостроительном факультете в своем региональном Политехе. На 3м-4м курсе пошёл работать по специальности в местечковое военное НИИ, а его на работе программировать микроконтроллер посадили.
После защиты диплома, через 6 месяцев подписал форму допуска и стал абсолютно серым телом без рта.
Потом вся оставшаяся жизнь протекает по схеме: сделал проект, получил премию 20kRUR, съездил в Анапу.
На большее рассчитывать и не приходится!
Религиозные аспекты в программировании микроконтроллеров
Ещё в программировании микроконтроллеров как нигде неимоверно много религиозных аспектов и вкусовщины на почве которой происходит много бессмысленных и беспощадных споров.
Например в выборе MCAL кода от вендора, одни ратуют за использование SPL, другие убеждают, что надо использовать HAL. Третьи продвигают LibOpenCm3. Вот реестр всех спорных моментов.
https://docs.google.com/spreadsheets/d/1SUSJK6F6SBazSU7hZ97SZnPrJ0myj836T34-Hs13BG4/edit#gid=0
А согласование общего текстового редактора это вообще война всех против всех.
Все эти моменты портят отношения и являются зерном серьезного конфликта. Это крайне неприятно перетирать. Компромисс в таких вопросах достигнуть неимоверно трудно. Найти работу, которая будет по всем пунктам соответствовать вашей техно-религии просто нереально. Конфликты и компромисс неизбежен...
В профессии программист микроконтроллеров нет женщин
Вернее они в этом деле случайно появляются по ошибке и недоразумению, но не задерживаются больше года, полтора. Знаю одну девушку-фифу бывшую программистку встраиваемых систем в России.
Как-то она на планерке спрашивала что-то типа
Как найти место на плате, чтобы подключить цепляшу электрода осциллографа к той микросхеме
Ей коллеги сказали что-то типа
Найди эту микросхему на плате по количеству пинов, она там такая одна.
После этого девушка сочла, что её жестоко оскорбили и расплакалась. Спустя несколько месяцев сбежала от этой пресловутой электроники сайты программировать на Python(не) и теперь счастлива!
Естественно женщины в профессии программист микроконтроллеров не задерживаются. Гаражные условия труда, провода, высокое напряжение, статическое электричество, матерщина, антистатическая обувь, посещение подземного цеха в комбинезоне для современных российских женщин всё это неимоверный шок и стресс. Разрыв шаблона о профессии программист.
Второстепенная работа
Работа программирования МК тесно связана с электронными платами. Если вы программист МК, то скорее всего вы будете по уши в электронных платах. Они будет на работе, дома на подоконнике, под монитором, на балконе. Словом везде. Вам придется не сколько программировать, сколько исправлять разнородные аппаратные баги, собирать прототипы. Железо часто подводит. Вот буквально несколько примеров.
Пример (№1 Клёщ в разъёмах)
Типичная ситуация в программировании микроконтроллеров. Отвалившаяся вилка застряла в гнезде. В электронике это называется "извлечь клеща".
В программировании микроконтроллеров "клещи" происходят на разных платах достаточно часто
И тут вам никакие знания алгоритмов и абстрактных структур данных не помогут, чтобы починить изделие и продолжить работу. Можно задавать в качестве вопроса для собеседования при приеме на работу на должность "программист микроконтроллеров". Как извлечь клеща (отломанную вилку)?
Пример №11 (Мусор между двумя разъёмами)
При включенном переходнике USB-CAN автомобиль не заводится. Стартер работает, но зажигания (вспышек в цилиндрах) не происходит. Разобрали половину впускного коллектора. Три часа искали причину поломки. Оказывается в OBD-II разъем попал кусок фольги от папиросок, которые замкнули три крайних пина.
Пример №2 (нет link(a))
Программатор не видит target по SWD. Собрали стенд, положили SWD длиной 90 см и нет Link(а) с MCU. Когда кабель 12 см, то link есть. Или нет Link(а) c SD картой по SDIO или SPI. Оказывается стерлись контактные площадки. Вообще проблемы отсутствия всяческого Link(а) в программировании микроконтроллеров будут красной нитью проходить через всю вашу карьеру. Особенно в случае беспроводных интерфейсов.
Пример №3 (не тот разъём)
Еще вторая тупая проблема это когда разъём на электронной плате не соответствует реальному разъёму на программаторе или на каком-н другом шлейфе.
И тут начинается конкурс "чей колхоз самый образцовый колхоз".
Или вот ручной зажим Tag-Connect не защелкнуть так как пальцы не пролезают между стабилизатором напряжения TracoPower и разъёмом Tag-Connect. Всё не предвидишь. Особенно когда плату разрабатывают полгода.
Пример №5. Плата работает под отладчиком, а при пересбросе питания не стартует прошивка. На другой плате это не проявляется. И эта ситуация потребует неделю на выяснение причины и устранение. И так для каждого нового чипа и каждого ToolChain(а).
Пример №6 "Да USB у него не той системы..."
Также проблема в электронике это USB. В каждой 2й плате есть интерфейс USB. Проблема в том, что во всех платах разный разъём для USB: USB mini, USB micro, Type-C! Ты постоянно будешь искать нужный для этой конкретной платы кабель USB.
У тебя будет целый гардероб из разных USB кабелей на каждый день, рядом с носками.
Плюс бывают ситуации, когда кабель USB у тебя есть, а вставить его ты не можешь, чёрт побери, так как упирается и мешает декоративная пластмасса!
Или на полевых испытаниях прибора в мороз -30 в темноте ты не видишь какой ориентацией вставлять разъём USB mini, который заложили растяпы-схемотехники, а руки от холода и так не слушаются. А USB micro гнездо имеет свойство откалываться от платы при малейшем поперечном изгибе и плату не запитать. В общем USB-это всегда большая проблема.
Пример №7 (платы без монтажных отверстий)
Схемотехники забыли/забили добавить по периметру платы монтажные отверстия 3мм. В результате программист 3 недели занимается вот таким современным искусством. Зураб Церетели отдыхает в сторонке
Даже если отверстия есть, то придется собирать прототипы самому, чертить детали из плексигласа, договариваться со слесарями, токарями, фрезеровщиками, чертить вот такие схемы для сборки прототипа пока основная плата находится в производстве. Потом капаться в интернет магазинах, чтобы найти стойки, болты и гайки. Заказывать, ехать, забирать, проверять.
подробнее про это можно почитать тут https://habr.com/ru/articles/709932/
Пример №8 (Не получить лог загрузки программы)
Схемотехник по глупости поставил в плату переходник USB-UART (CP2102). Получается, что сначала MK начинает исполнять код и писать в UART, затем спустя несколько секунд Windows определяет последовательный порт. В результате не получить power-on log загрузчика.
Пример №9 (припаяли компонент не той стороной)
В профессии программист микроконтроллеров часто бывает так, что Вам приносят электронную плату с производства, а эта плата не работает да еще и с целым букетом аппаратных багов. Даже если правильная схемотехника то может оказаться неправильная сборка.
Наверное производителями электронных компонентов надо наладить производство трапециевидных корпусов
специально для россиян для всех электронных компонентов, чтобы исключить эти извечные проблемы с неправильной ориентацией при пайке.
Пример №10 (тугие разъёмы)
В программировании микроконтроллеров есть такая специфическая проблема как тугие разъёмы. Можно полдня потратить на то, чтобы просто отцепить шлейф от тугого прикипевшего разъёма на электронной плате. В силовой электроники ситуация еще хуже. Там железные разъёмы-клеммники и вовсе от высокой силы тока просто привариваются к плате инвертора. И чтобы продолжить работу вы вместо клавиатуры работаете с болгаркой.
Пример №12 (пайка под микроскопом)
Для того чтобы отлаживать прошивку с крутыми ASICами вам придется анализировать сигналы на осциллографе в шине I2C. Для извлечения сигнала для анализа из I2C тебе придется подпаиваться к тест Pad(ам) на электронной плате тонюсенькими как волос проводами МГТФ. Чтобы Вы понимали, это очень ювелирная работа и производится как правило под микроскопом с увеличением в x70 x100 Zoom. Схемотехники будут всяческие отказываться помогать вам в этом ссылаясь, якобы, на циклопическую загруженность другими проектами. Поэтому прокладывать МГТФ проводку под микроскопом приходится самим программистам-микроконтроллерам, программистам-архитекторам. Вот так. А вы как хотели?
---------------------------------------------
Суммируя аппаратные баги можно подвести черту, что это либо ошибка в схемотехнике (забыли подать тактирование на чип), или ошибка в топологии. Обычно это короткое замыкание, квадратную микросхему припаяли повернув под углом 90 градусов, кварц установили не на ту частоту, либо заложили чип с инверсными логическими уровнями или вовсе там бракованные микросхемы.
Потом статическое электричество будет постоянно портить вам жизнь. Были случаи, когда ставишь электронную плату на недельный тест. Приходишь через неделю снять ценнейшие логи. Только дотрагиваешься до края электронной платы, и проскальзывает искра статического электричества, которая убивает прошивку. И весь недельный тест накрывается медным тазом! Вот такие пирожки с капустой...
Свежие электронные платы с производства не любят работать. Предпочитают сразу сгорать. Буквально подаешь питание и плата начинает шипеть как гадюка. Разные разъёмы будут не контачить и прочее. Аппаратные проблемы будут еще до запуска кода. На программирование после починки плат остается очень мало времени. И вы тут как программист-микроконтроллеров ну ничего не сможете сделать, чтобы дописать и отладить свою программу. Программу банально не на чем отлаживать.
У меня был случай когда три схемотехника спроектировали электрическую цепь электронной платы (схемотехнику), развели топологию, отправили производство, a на выгоде выяснилось, что они забыли вообще даже подать на микроконтроллер питание! Как говорят
У семи нянек дитя без глаза
В каждой электронной плате 30%...40% всех микросхем - это тупо микросхемы для управления электропитанием. Всякого рода переходники напряжений, для установки 1.8V, 3.3V, 5V, 7V, 8V 12V, 24V. Поэтому 60 % времени разработки прибора уйдет на поиск и ликвидацию проблем в цепях электропитания. И только 30%..40% времени останется на авральную разработку функционала приложения для которого и была запланирована вся эта микроконтроллерная разработка...
На сам процесс программирования уходит максимум 10...20% времени. В основном приходится что-то бесконечно ремонтить, разбираться с проводами harness(a), искать и закупать примочки. Вы будете постоянно искать этот 20-пиновый шлейф для программатора. Каждый день вам придется тратить 30..45 минут просто на то, чтобы тупо распутать и распетлять провода. Потом 4 часа искать второй щуп от мультиметра (это который красного цвета), затем ехать в в ближайшее метро, чтобы купить 9V батарейку типа КРОНА для этого мультиметра. Вернуться в промзону. Выяснять, что куда подключено, собирать прототип. Обязательно потеряется четвёртый крючок-наконечник для щупа осциллографа. Потом проверять электродами осциллографа наличие электрических сигналов, прозванивать провода, проходить по чек-листу.
Не успеешь разобраться с одной электронной платой, как тебе принесут ещё две-три электронные платы и надо будет вкуривать очередную схемоту на 40-60 страниц. А схемотехник, редиска, даже блок-схему не нарисует, сразу даст в лучшем случае электрическую принципиальную схему (Э3) в виде, внимание..., фотографии *.JPG! (Там поиск по ключевым словам не работает). А в обычном случае и вовсе принесёт плату вообще без доков и скажет, что её тоже надо "оживить"!
Можно запросто неосторожно сжечь оборудование из-за неправильно подключенного заземления. Вы обязательно узнаете как пахнут искры. Они имеют свойство залетать прямо в нос! Можно потратить весь день на подключение лампочки или чтения состояния зашумленной кнопки. Копаться в разъёмах. Выяснять почему цифровой сигнал не проходит через каскад мультиплексоров.
В профессии программист микроконтроллеров ты почувствуешь физику по-полной: лампочки тебя будут ослеплять, аудиокодеки-оглушать, радиаторы-обжигать, моторы-задевать, напряжение-ударять, бетта-лучи, соответственно, облучать.
Трудоёмкость отладки и поиска ошибок внутри прошивок
Невозможно найти ошибку в программе только пялясь на код. Чтобы найти ошибку в программе программу надо запускать на исполнение! Анализировать run-time, логи, делать выводы и только потом осознано редактировать код.
Результат твоей работы будет напрямую зависеть от результатов работы предыдущих этапов работы схемотехника, тополога и монтажника. Если тебе дали электронную плату с не теми припаянным SMD резистором 0402, то ты, как ни крути, не сможешь отладить и написать свой код. На нужный чип просто не поступит тактирование.
На работе из тебя всегда все будут делать должника. Должен прошивку, должен фичу, должен функционал, должен выполнить реверс инжиниринг протокола, должен починить чужие баги и прочее, и прочее.
В программировании MCU с Вас будут спрашивать за функционал прошивки. Однако для разработки и отладки функционала прошивки нужен надежный прототип. Схемотехники будут всячески юлить и отказываться делать для тебя прототип под предлогом, что они не хотят покупать примочки для прототипа. Схемотехник придумает любую причину чтобы этого не делать, вплоть до того, что скажет будто его вчера лиса укусила. В фэнтези-мире схемотехников клей, гвозди и синяя изолента - это лучшее решение всех задач по сборке прототипа.
Поэтому вам как программисту МК также скорее всего придется заниматься конструированием прототипов самому. Это черчение конструктива прототипа, переговоры с производством конструктива, покупка крепежа. Кто хоть раз делал прототипы, тот знает, что тут много нюансов. И на это будет уходить много времени. Как следствие на разработку функционала и поиск багов будет оставаться мало времени.
А чтобы отлаживать код, его надо исполнять. Если в коде баг и нет возможности исполнить код (нет электронной платы), то баг не исправить! Понимаете? Это как писал философ Э.В. Ильенков, если найти в лесу отдельно лежащую человеческую ногу, то не ясно что это такое и зачем нужно. Понятно только, когда эта нога видна в действии (в составе идущего по улице человека или во время танцулей). Аналогично в понимании причины программных багов. Надо запускать код!
А накладные расходы на запуск и исполнения микроконтроллерного кода при разработке на MCU в составе комплекса порой огромные! Знакомые, которые разрабатывали firmware для военных авиационных ECU писали, что одна минута испытаний реактивного двигателя на стенде стоит 300k RUR. Естественно, затраты на испытания вычитают из зарплатного фонда для программистов-микроконтроллеров.
Команда из компании Третий Пин потратили весь 2017 год на выявления 2х Шрёдинбагов в их Пастильде. Оказалось, что в конфиге был указан не тот Flash Latency и в схемотехнике не тот номинал емкости в цепи питания. И в программировании микроконтроллеров это нормально.
Мало ресурсов
Программисты МК в принципе не пишут больших программ. Размер проектов ограничен несколькими сотнями килобайт памяти Nor Flash(а). Обычно 320KByte на всё. Вас будет преследовать постоянная нехватка on-chip Nor Flash памяти.
Особенно при разработке первичного загрузчика (16kByte) и вторичного загрузчика(64...128kByte). В принципе невозможность сделать полноценный загрузчик по всем интерфейсам.
С RAM ситуация еще хуже. Вам повезет, если размер RAM будет в 4 раза меньше чем Flash(а). Вы регулярно будете ловить исключение HardFault_Handler из-за переполнения стека. А частоты микроконтроллеров не превышают 200MHz, так как весь смысл МК это низкое энергопотребление.
Если микропроцессор x86 это миксер для чисел, то микроконтроллер это ступка для чисел. В MCU ты знаешь начало и конец RAM памяти и её мало.
После программирования микроконтроллеров, с его вечной нехваткой ROM/RAM памяти, запретом динамического выделения памяти, составление программ в User-Space под DeskTop покажется тебе Манной Небесной!
Даже не мечтайте про удалёнку из Тайланда.
Чтобы в принципе делать embedded software нужен физический доступ к многочисленному и разнообразному калейдоскопу всяческого промышленного оборудования. Нужен программируемый блок питания, чтобы выставить 1.8 или 24.0 Вольт. Нужна проверка сигналов осциллографом, подключение логического анализатора к I2S, измерение DMM(ом) с функцией TrueRMS, работа с микроскопом для проверки, что микросхемы правильно припаяны. Нужен анализ перегрева электронной платы тепловизором. После пайки нужно отмывать электронные платы в ультразвуковой ванночке. Антенны надо прозванивать векторным антенным анализатором VNA пред привинчиванием. Нужна лазерная резка по плексигласу для изготовления подложек прототипов, нужен 3D принтер для прототипирования корпусов, нужны всяческие отвёрточки: шлиц двоеточием, шлиц треугольником и пр.
Это главное и основное отличие программирования-микроконтроллеров от, например, того же Web программирования. Едва ли вообще можно эффективно работать в роли embedded удаленно. Это как удаленно от плиты готовить еду, удаленно красить стены, строить дом или удаленно работать воспитателем в детском саду. Программист МК - это профессия производственная и тут нужно физические первостепенное воздействие на прототип или изделие.
В довесок к этому твой ежедневный будничный рюкзак будет наполнен до отказа всяким барахлом, которое тебе придется таскать с собой в метро или Bus(е), если ты вдруг захочешь что-то поделать из дома с пиратским софтом вечером или на выходных.
Если Вам предлагают работать программистом-микроконтроллеров удаленно, то просто посылайте таких рекрутеров лесом!
Образовательный BackGround
Самым полезным background-ом для профессии программист микроконтроллеров я бы назвал профессию разнорабочий/чернорабочий. Программирование микроконтроллеров это на 80-70% электротехника и только на 20-30% программирование. Надо будет делать прототипы и ремонтировать сгоревшие платы. Вытравливать электронные платы методом ЛУТ (лазерно-утюжная технология).
Что такое ЛУТ можно посмотреть тут https://habr.com/ru/articles/713970/ Если коротко - это жесть. Когда я делаю плату ЛУТ(ом) у меня в среднем остается 3 пореза на руках.
Будучи программистом микроконтроллеров вы будете метаться по блошиным радио-рынкам в гетто районах чаще, чем посещать магазины с одеждой и обувью.
Потом выяснять, почему электронные платы с производства не включаются. Предстоит делать закупки примочек, работать курьером, прокладывать проводку, чертить 2D и 3D детали, трассировать печатные платы, паять под микроскопом, измерять электрические сигналы, выпиливать, клеить, шкурить, затачивать сверла, сверлить, фрезеровать, крутить разные отвертки, покрывать электронные платы лаком, настраивать 3D принтер, пылесосить, ездить на автомобиле с ноутбуком на коленях, снимать на камеру ролики для выставок. Монтажировать видео. Делать реверс инжиниринг более успешных западных товаров. Настраивать tool-сhain(ы) и многое-многое чего ещё.
Вам повезет, если вы вообще за неделю будете хоть что-то программировать в этой чудо-юдо профессии программист-микроконтроллеров. Если же Вы будучи программистом МК не станете исполнять все эти функции чернорабочего и будете, упаси Бог, проявлять принципиальность и вставать в позу, якобы
Да я тут только код пишу!
то Вы попросту будете тормозить ход всей работы и Вас публично обвинят в саботаже. Далее вас будут всячески изживать из коллектива и из компании.
Прошивки это всегда простые и тривиальные программы
Да и программы для МК на самом-то деле очень простые. Вся работа прошивки - это перекладывание байтов. Из интерфейса в память. Из памяти в интерфейс. Прочитать по ADC напряжение и выполнить функцию.
В программировании микроконтроллеров самая большая радость - это когда просто мигает лампочка на электронной плате.
Все что вам понадобится из теории computer science (CS) это теория конечных автоматов, очень редко PID регуляторы, самые базовые и простецкие структуры данных как массив, FIFO(шка), циклический массив).
Очень маловероятно, но может пригодится бинарное дерево поиска для реализации простого NVRAM во внешней памяти. https://habr.com/ru/articles/732442/
Пару раз вероятно пригодится динамическое программирование, чтобы просканировать шину RS485. https://habr.com/ru/articles/752292/
Может пригодятся численные методы. Плюс цифровые фильтры, преобразование Фурье, триггер Шмитта и AES шифрование для загрузчиков. Вот, пожалуй, и всё...
Остальная громадная классическая теория Computer Science (CS) будет Вам скорее мешать, чем наносить пользу. Я вот ни разу не видел LIFO, AVL деревьев, красно-черных деревьев, косых деревьев в исходниках каких бы то ни было прошивок, хотя onen-sourc(а) насмотрелся порядком. Ни разу не видел хеш-таблиц, фильтров Блума, графов. Все это добро в большинстве своем даже с доплатой не нужно в программировании микроконтроллеров.
В программировании микроконтроллеров 95% случаев нет никакой академической математики или классических алгоритмов из CS. А если на горизонте и вырисовываются такие логические задачи, то это становится праздником, подарком судьбы для программиста МК. Сотрудник с удовольствием делает эту часть работы, а потом ещё и пишет про это пост на habr и рассказывает всем как он здорово справился с этой ситуацией.
№ | Тема | URL |
1 | DFT в прошивке | |
2 | FSM для определения обрыва в цепи* | |
3 | FSM для кнопки | |
4 | DSA для парсинга float числа* | |
5 | Динамическое программирование для сканирования RS485** | |
6 | BST для SPI-Flash NVRAM*** | |
7 | DS-TWR для UWB* | |
8 | Вывод формулы для DS-TWR | |
9 | Теория управления шаговым двигателем*** | |
10 | NVRAM для on-chip flash** |
Но за 12 лет у меня было только 7-10 таких случаев. В сумме 3-4 месяца по-настоящему интересной творческой инженерной работы. А остальные годы это просто рутина и тягомотина по перекладыванию байтов и починке чужих багов.
Причем половина от всех этих математических вкусностей Вам понадобятся даже не сколько в работе, сколько в pet-проектах.
Даже если Вы будучи программистом MCU и научитесь чему-то особенному и необычному, то это скорее всего нигде тут не пригодится. В России традиционно электронику делают очень-очень топорными способами:
--без сборки из скриптов,
--без модульных тестов,
--без серверов сборки,
--без кодо генерации,
--без HIL стендов.
Просто тупо пишут функционал и точка. Если Вы будете учиться, то уже через 2 года Вы точно будите overqualified. Вот Вам яркий пример... Выучили Вы например CMake (отличный инструмент, без шуток), приходите работать в военное НИИ AФАР-радары программировать, а там до Вас дедушка прошивки собирал из-под IDE-IAR 15 лет подряд. И что? Вы будете CMake скрипты писать для 150 файлов из распакованного *.zip архива? Нет конечно же. Более того, Вас за такое уволят еще на испытательном сроке! Уж поверь мне...
Понимаете, в России лояльность и конформизм важнее мастерства!
Российские организации у программистов микроконтроллеров больше ценят умение вручную трассировать печатные платы в P-CAD и умение руками паять SMD компоненты (без микроскопа), чем все эти Ваши моднявые IT(шные) технологии как DevOps, сборка из скриптов, модульные тесты, кодо-генераторы. Да.. Вот так.. Понимаете?
Российские компании не хотят нанимать опытных программистов-микроконтроллеров. Опытные знают себе цену и у них сформировался свой почерк, свои инженерные привычки в коде и отладке. Российские компании, напротив, больше предпочитают нанимать вчерашних желторотых студентиков, юнцов. Происходит это по двум причинам:
1—Экономия на зарплате. Вчерашнего студента легко унизить на собеседовании и склонить работать за зарплату вплоть до 25к-42к RUR в мес. А сэкономленное рассовать по карманам начальства. Поверьте, в российских инженерных НПЦ деньги есть всегда, и большие. Это видно по составу иномарок на парковке, мерины, BMW X5, Ауди Q5.
2—Научить юнца под себя, то есть научить малыша своим плохим практикам. Зачастую вчерашние ВУЗ(овцы) ещё не знают о таком понятии как технологии промышленной разработки ПО, поэтому в их голову можно легко вложить любое извращённое убеждение, даже самое абсурдное, например, что передавать код проекта в *.zip архиве по почте, и сборка из-под GUI-IDE мышкой - это вообще норма жизни, и тому подобное.
Однако, вернемся к тезису о простоте программ для микроконтроллеров... Даже если программа для MK Вам кажется сложной, то это значит только то, что программа неправильно написана. Вот примеры пере усложнения кода (обфускация) из жизни (War Story)
1-Плохая архитектура всего проекта.
2-магические циферки на каждой строчке
3-доступ к регистрам в каждом файле проекта
4-повторяемость кода, дублирование кода.
5-Написание тривиальных проектов на С++ вместо Си
6-очевидные комментарии
18--Не пользоваться оператором switch(), а в место него всё делать лесенкой из операторов if().
7-"заборы" из комментариев ///////////////////////////////////
8-отсутствие сортировки #include(ов)
9-отсутствие сортировки прототипов функций
10-*.с файлы оснащены не одноименными *.h файлами.
11-макросы маленькими буквами
12-вся прошивка в одном main.c файлике 75000 строк аж подвисает текстовый редактор.
13-код без модульных тестов или код перемешанный с тестами
14-функции от 1000 до 5000 строк и более
15-Использование RTOS там, где это не надо
16-Вставка препроцессором #include *.c файлов.
17-Функции с именами литературных персонажей
Всё это провоцирует мысли, что якобы программировать МК это сложно. Однако при соблюдении элементарных хороших практик программирования, программы для МК получаются простыми и прозрачными. Не надо путать сложность и пере усложненность. Зачастую намеренную (см обфускация кода) с целью быть незаменимым сотрудником в организации.
В добавок к этому, так как частота микроконтроллера маленькая, то прошивки крутят довольно простые программы. В прошивках, как правило, нет никакого процессинга над данными и нет никакого computing(а). Быстрее бывает отправить данные на Web сервер, чтобы рассчитать что-то там и принять ответ, чем считать что-то на MCU. А если и есть процессинг, то вендоры прячут ЦОС в статические библиотеки (LС3, CIC). Поэтому Вы не сможете оценить красоту алгоритмов и структур данных.
Прошивки - это прочитать значения из датчика и показать циферку на экранчике. Всё сводится к тому, что надо GPIO мигнуть, кнопку прочитать, испустить PWM сигнал и прерывания по перепадам напряжений отловить. В микроконтроллерах нет нужды даже в алгоритмах сортировки. В сущности прошивки только прописывают константы в регистры и считывают регистры SoC(а). А это, в свою очередь, приводит к активации электрических цепочек внутри SoC(а). Со стороны вся цифровая электроника только и делает всего-навсего 4 простых действия:
1--установить на проводе 0V
2--установить на проводе 3.3V
3--считать с провода 0V
4--считать с провода 3.3V
Машина Тьюринга. Вот и всё. Easy!
Программы для МК в основном нужны там, где надо быстро сигналы обрабатывать. Для управления любыми двигателями (прошивки-спиннеры), для считывания датчиков физических величин. В таких вещах не должно быть никакой осечки и неожиданного поведения. Во встраиваемых системах не будет всех передовых технологий как MMU, Cache, динамического выделения памяти. Так как они не дают гарантии на время отклика. Есть правила MISRA, которые вообще запрещают много интересного. Вот они.
https://docs.google.com/spreadsheets/d/1yHserq9AY0wNc5kbwriT_orr5LVbfv4ktDXRSDwYiR8/edit?gid=0#gid=0
Например MISRA запрещает, динамическую память. Нет динамической памяти, а значит нет и абстрактных структур данных. Нет сортировки слиянием, нет быстрой сортировке. Запрет на функции из stdio.h и time.h, запрет рекурсии, запрет на Variable Length Array (VLA). Такой обрубленный Cи исключает какой бы то ни был процессинг внутри прошивок.
В программировании МК как такового программирования-то мало. В программировании МК не происходит ничего особенного. Как правило такие программы принимают пакеты из интерфейсов и что-то прописывают в интерфейсы или читают датчики и передают показания в интерфейсы. Принимают прошивку и прописывают её во Flash память. В основном задачи вида прочитать SPI датчик и переслать значение в провода. Получить из проводов команду и включить лампочку. Получить из проводов массив и прописать его в энергонезависимую память и т.п.
Разработчик MCU обычно за 3-5 месяцев полностью выполняет проект и переключаются на другой. В микроконтроллерном программировании всё очень топорно устроено.
Много работы с перекладыванием бумажек
Для программирования микроконтроллеров надо очень хорошо ориентироваться в множестве официальных документов.
Вникать в спецификацию компилятора (~1k страниц), стандарт языка С (~700-1k страниц), спецификацию процессорного ядра (~300 страниц), спека RTOS(а) (~250 страниц), обязательно ознакомиться с перечнем ошибок проектирования кристалла (~20 страниц), вникать в спеки каждой микросхемы (~50...5k страниц) на печатной плате. Искать куда идут провода(~1-100 страниц). Читать логи сборки (300 страниц) Стандарт функциональной безопасности ISO-26262 (450 страниц). Вникать в спецификации BlueTooth LE (1 профиль-500 страниц). Вникать в спецификации других беспроводных интерфейсов (320 стр)*60. Вникать в спеки бинарных и текстовых протоколов: TCP/IP, J1939, CANOpen, DLMS, ModeBUS, MQTT, LoRaWAN, UBX, NMEA, xModem, Pelco-D, ASN.1, RTCM 3.x. Читать RFC. Всё на английском. Некоторые спецификации надо покупать. Плюс каждая российская организация, колхозит еще свой собственный никому больше не нужный бинарный протокол и выпускает про него спеку (60 страниц). В общем читать, читать, читать.
Вам придется как юристу очень много пылиться в чтении официальных документов. Вы однозначно будете читать больше чем программировать. В профессии программист-микроконтроллеров 20% времени - программирование и 80% времени - перекладывание бумажек.
программист-микроконтроллеров = курьер
В российских военных компаниях полностью бумажный документооборот. Там нет Jira или яНДЕКС Трекера. Поэтому Вас как программиста микроконтроллеров будут частенько использовать как пневмопочту по городу и области -+70км в другие НИИ и ФГУП(ы). Иногда будут давать водителя на убитом Renault, а иногда нет. Бывает идёшь на работу и думаешь, что сегодня будешь программировать в прошивке абстрактную структуру данных из учебника Axo, а в реальности полдня сидишь в Renault Logan в зимней пробке внутри вейпингового облака и вдыхаешь "дым отечества" курева водителя.
Невозможность монетизации
В разработке прошивок в принципе не может быть никакой монетизации, как в Web сайтах. Никто не будет вам платить 10$ в месяц за аккаунт в прошивке. Это было бы ну просто смешно.
Цена прошивки без физического устройства 0 рублей 0 копеек. Продажи прошивок жестко ограничены продажами электронных устройств, которые крутят эти прошивки. А количество электронных устройств жестко ограничено производственными возможностями конкретной организации. При этом в России нет массового производства никакой электроники. Просто былая промышленность СССР утрачена, продана, угроблена.
Программист-микроконтроллеров нужен там, где есть развитая продуктовая разработка. А продуктовая разработка - это не типичная деятельность для России. Нынешняя Россия - это общество перепродажи заграничных товаров и оказание услуг по манекюру и ресницам.
В нынешних российских электронных организациях как правило мелкая серия электроники 100..500 штучек чего-либо за весь жизненный цикл продукта. Причем сами электронные платы обычно паяют в подвалах вручную 2...3 грустные тётушки бальзаковского возраста. Выглядит всё это очень удручающе... В yield(де) как правило 60% брака. Сами понимаете, что много народных гаджетов так не наклепаешь.
При этом стоимость конечного российского изделия на MCU (какой-нибудь очередной пресловутый СКУД) редко превышает 10k...30k RUB.
Вот ещё, например, компания ГК Телесистемы, которая сделала на микроконтроллере крутой нишевый диктофон и теперь страдает от того, что рынок очень маленький и продажи слишком низкие, и невозможно инвестировать в развитие и рост организации. https://habr.com/ru/articles/822375/
Ну сами представьте, сколько может стоить работа по написанию I2C драйвера для микросхемы AT24C02M5 стоимость которой 11 рублей (0,12 USD)? И какое отношение у предпринимателей к такой работе?...
Поэтому программисты микроконтроллеров - самые низкооплачиваемые программисты в России 42k..70k RUR/меc, работающие в массе своей за идею. Просьба отнестись к этому с пониманием...
Оно Вам надо?
Низкий престиж профессии программист микроконтроллеров в российском обществе
Приведу только два примера.
Когда я поздно вечером после 23:00 прихожу домой с работы программистом-микроконтроллеров я обнаруживаю дома как мой брат (отличный автослесарь) играет в видеоигры на DeskTop PC. Что-то типа GTA-5, Crisis или Half-Live 2 и поговаривает:
Вот этих программистов я уважаю! Отличную компьютерную программу написали парни! Какая физика! Какое динамическое освещение! Сразу видно, знатно поработали ребята!
Он пристреливает очередного Combiner(а). Потом он поворачивает голову в мою сторону и говорит:
А то, что ты там программируешь в своей северной промзоне 10й год по 3й форме допуска, я до сих пор не знаю...
Вот! Посмотри сам. GameDev программисты игр и являются True-Программистами, а ты, embedder, вообще не пойми кто!
Большинство моих знакомых (соседи, попутчики в электричке, дальние родственники) даже не подозревают, что в России вообще занимаются какой-то электроникой. При словосочетании "российская электроника" у них просто перекашивает лицо...
А в регионах нашей необъятной прекрасной Родины жители и вовсе испытывают средневековый суеверный страх перед электроникой... Буквально в 440 км от Москвы я лично слышал от местных фразы типа:
Накой нам Ваша электроника? От неё люди болеют!
Вот так, господа....
Программист-микроконтроллеров это устаревшая профессия
Прошли те времена когда у программистов MK было много по-настоящему интересной и разнообразной работы.
Прошли времена отдельно стоящих магнитофонов, CD player(oв), iPod(ов), лазерных считывателей штрих кодов, игровых приставок Dendi и Тамагочей. Прошли времена пейджеров и кнопочный мобилок от Siemens\Nokia\Motorola, прошли времена отдельных диктофонов, отдельных mp3 плейеров. Прошли времена отдельных устройств навигаторов (Garmin(ок)).
Все эти устройства работали под управлением микроконтроллера внутри. Сейчас всё эти микроконтроллерные устройства - даже не музейные экспонаты, а товары блошиных рынков в гетто районах вашего города.
Нынче же вся телефония и всё мультимедиа (телефоны, маршрутизаторы, HMI), кассовые терминалы в магазинах, принтеры в офисах и даже игровые ретро-приставки Sega (SG800)- это всё Еmbedded Linux. Нынче всю электронику выгоднее проще и дешевле делать на модулях c Embedded Linux (типа skw92) с OS Android или Arch Linux внутри. Сейчас всё в смартфоне! Люди не хотят носить с собой ничего электронного, кроме смартфона. Понимаете?
Реалии таковы, что умение программировать user-space приложения под Android на Kotlin или iOS на порядок ценнее, чем умение программировать System Software для микроконтроллера на Си!
Ну сами подумайте, ну где Вы собираетесь программировать эти пресловутые микроконтроллеры, кроме как не в кружоке робототехники "за идею" в качестве благотворительности? Можно пойти ещё в сервисный центр ремонтировать бытовую технику: холодильники, стиральные машинки, микроволновки где-н в подвале ТРЦ.
Вы конечно можете разработать и сделать крутой офисный степлер со счётчиком оставшихся скобочек, с OLED дисплеем, логгером событий скрепления бумажек на SD карточку, но кому будет нужен такой навороченный степлер?
В России нет целой кучи секторов экономики, где пригодились бы навыки программиста микроконтроллеров: нет станкостроения, нет производства электронных компонентов, нет электроники для hi-thech сельского хозяйства, нет разработки мобильных телефонов, нет разработки планетоходов и т. д.
По факту, MCU теперь в России нужны только в automotive и military. Automotive - классный вариант, без шуток (даже АвтоВАЗ), однако сильно подвержен кризисам и сокращениям штатов, а в military не зарплаты, а "зачисление корма". Уж поверь мне я 3 года работал в military.
Чего вообще хорошего в профессии программист микроконтроллеров?
Однако не всё так плохо. Если сильно-сильно постараться и пофантазировать под вэйпингом, то можно найти причину и даже внутренний огонёк (свечку), чтобы продолжать заниматься программированием микроконтроллеров.
1--Первый плюс (Всё упирается в физику)
Первое достоинство этой работы в том, что тут всё конкретно и завязано на физические величины. Всё можно измерить. Есть полный контроль за устройством. Никакой OS, которая вдруг начнет обновлять антивирус на МК нет. На MCU нет виртуальной машины, нет гипервизора. Нет никакого недоверенного кода.
Всё можно оцифровать, любую физическую величину перевести в цифру. Всё упирается на физику и законы физики. Софт произрастает от схемотехники. Схемотехника произрастает из электротехники.
Как говорил наш университетский профессор
Электроника - это наука о контактах! Либо контакт есть, либо его нет...
Электротехника произрастает из физики. Никто не будет спорить с законами физики. Закон Ома не отменишь, как радугу! Достаточно по диагонали просмотреть электрическую принципиальную схему устройства (Э3) и уже в общем-то становится понятно, что это такое и какое для неё должно быть firmware.
2--Второй плюс (созерцание материальных ценностей)
Товар сразу видно, его можно потрогать, показать, покрутить. В этой профессии создают настоящие материальные ценности. Именно программисты микроконтроллеров создали Tomahawk(и) и Javelin(ны), которые поменяли так много событий в стольких многих местах. Hi-Tech оружие с микропроцессорным управлением, оно способно поворачивать мировую историю вспять.
Именно программисты микроконтроллеров создали ABS, ESP. Именно программисты MK написали прошивку для кардиостимулятора. Именно программисты микроконтроллеров написали прошивки для марсоходов Sojourner, Curiosity, Opportunity, Spirit, Perseverance.
Благодаря разработке firmware программисты микроконтроллеров расширяют границы возможного! Создают продукты, которые любят во всем мире (например USB-Flash(ки)).
3--Третий плюс. (Простота и топорность).
Язык Си по сравнению с другими языками программирования самый простой язык программирования. Простой как ножик! Одни только функции и переменные. Ну что может быть проще? Красота! В программировании на Си не будет никаких программных делегатов как в C#, шаблонов, наследования, виртуальных деструкторов, контейнеров, перегрузки функций, нет сборщиков мусора, исключений и виртуальных машин, нет байт-кода. В программировании микроконтроллеров Вы никогда не услышите таких страшных слов как "FrameWork".
Более того в программировании микроконтроллеров строго осуждается, порицается и возбраняется так называемое "FrameWork(остроительство)"! Вплоть до увольнения с работы! Главный принцип в разработке это KISS и YAGNI. Никаких бантиков, пасхалок и стразиков в прошивках быть не должно в принципе! В программировании микроконтроллеров только один паттерн: конечный автомат и только одна абстрактная структура данных - это массив.
4--Четвертый плюс (Консерватизм).
Ещё в профессии программист МК, как в деревне ничего не меняется десятилетиями буквально сквозь века (XX-XXI). Си - самый древний язык из тех, что всё еще используются. Си(шнику) более 50 лет. Постоянный консерватизм в наборе технологий. Что в 2011 в военном НИИ мы программировали Cortex-M3 в IAR на C с классами, так и c 2021(го) в яНДЕКС.драйв всё так же программируют Cortex-M3 в IAR на С c классами. Поэтому эта работа подойдет для тех кто не очень-то хочет непрерывно доучиваться чему-либо. Обычно в этой профессии кристаллизируются вчерашние ВУЗ(овцы), которые еще не поняли, что вовремя перейти в Java разработку - это лучшее, что может с ними случится в жизни, и много пенсионеров, которые уже просто не могут освоить что-то ещё другое. Ибо с возрастом утрачивается способность мыслить последовательно.
5--У вас будет интересное хобби
Если ты программист-микроконтроллеров, то у тебя будет большой выбор в том какое себе завести хобби. У тебя будет достаточно знаний и экспертизы чтобы сделать свой радио управляемый самолётик, умный дом, CNC станок на балконе и прочее в этом же роде. У тебя не будет вопроса как провести выходные, отпуск или гос. праздники. Родственники и знакомые будут тебя называть Кулибиным, Черепановым, Ползуновым или Косым Левшой. Твоя спальня будет больше похоже на цэх. Хобби будет, пожалуй, единственной радостью в твоей жизни...
6--Пятый плюс (никто не говорит тебе под руку).
Работа инженером в России хороша тем, что начальство, как правило, тебе не мешает. Как я уже упоминал, Начальство это в прошлом схемотехники, конструкторы, чертёжники, кто угодно но только не программисты и оно понимает, что ничего в Си-программировании не понимает и просто предпочитает не мешать программистам-микроконтроллеров работать. Или зачастую начальство программистов микроконтроллеров просто считает, что погружаться в подробности технической реализации схемотехники или программы прошивки продукта компании - это ну просто ниже их достоинства... Да, господа, именно так.
Поэтому в 5ти случаев из 7ми никто не будет говорить тебе что-то под руку и стоять над душой. Никто не будет шипеть над ухом. Никто не будет критиковать твой микроконтроллерный системный код. Никто его даже смотреть не станет. Вот так и живем...
Давно прошли времена Сергея Королёва и Олега Антонова. Сейчас начальство безучастное. В детали продукта предпочитает не вникать. Присутствует только номинально и не воодушевляет коллектив инженеров на великие дела.
Вывод.
В целом профессия программиста микроконтроллеров такая как я тут написал. Мало программирования и много проводов. Если у вас есть выбор и вы хотите программировать на разных языках и быть в теме классической программной теории, если вам 20..25 и вы решаете как орешки олимпиадные задачи с LeetCode и хотите использовать в работе современные и классические алгоритмы и структуры данных, если вы хотите быть в авангарде IT индустрии, то программирование MK вам точно не подойдет. Да... Тут просто не нужно ничего кроме FIFO и конечных автоматов.
Займитесь лучше Back-End(ом), Front-End(ом), Web(ом), нейросетями, GPU, мобильными приложениями, Data Science, Zero Coding, базами данных, GameDev(ом). Слава и деньги именно там!
А еmbedded-мир сильно отстает от "большого IT" (прежде всего Web(а)). Как правило в embedded нет систем контроля версий сорцов, нет сборки из скриптов, нет менеджера пакетов, нет командной работы, нет планёрок, нет автосборок, нет авто тестов, нет инспекции программ, нет KanBan(а), нет DevOps(а). Зарплаты программистов микроконтроллеров 2-3 раза ниже чем в WEB(е).
Программист микроконтроллеров в окружении Web программистов обычно выглядит как дровосек в сообществе учёных.
Вам не кажется странным почему культовый сериал "Кремниевая Долина" сняли не про программистов микроконтроллеров, которые пишут прошивку для нового SSD, а про Web программистов, которые пишут компрессию данных? Почему главные герои не ходят там в комбинезонах по чистым комнатам гигафаба? Где в сериале, собственно, кремний-то?
Тот же С++ и то более живо развивается и конвертация навыков выше. В С++ появились стандарты 11, 14, 17, 20, а plain С это 89, 99, 2011 и, кажется, всё.
Если сравнивать программирование микроконтроллеров с web программированием, то это как водитель вертолета и водитель пассажирского авиалайнера. У WEB программистов существенно более мощная вычислительная техника (сервера, DeskTop(ы)), их продукт обслуживает миллионы людей. Их как пилотов Boeing 737 окружает слава и внимание.
У программистов - MCU наоборот слабенькие процессоры. Программа для микроконтроллера служит, как правило, только одному единственному человеку (например прошивка для кардиостимулятора). Зато программисты MCU ближе к контролю real-time процессов. Подобно тому как вертолетчики могут приземляться и взлетать вертикально.
Как по мне, если сравнивать разные программирования с музыкальными инструментами, то Back-end, Front-End разработка - будет рояль. Огромные залы слушателей, оркестр. Всё выглядит дорого и богато. От мызыки аж захватывает дух. GameDev - это саксофон или гитарка на которой поют для небольших групп, кто пришли послушать песенки. А программирование-микроконтроллеров - это, друг, губная гармошка, на которой играют самому себе под нос какую-то грустную мелодию.
Вы хотите участвовать в этом цирке с конями?
По моим наблюдениям за 10 лет в среднем трое из пяти, кто начинал с программирования MK спустя 3 года переметнулись в другие виды программирования (Python, Go) или совсем в другое (строительство, танцули, сомелье, дьяконы РПЦ). А программирование МК(ашек) это реально для тех, кто готов закатать рукава, замарать руки и регулярно выходить из зоны комфорта.
Если же Вы всё же по каким-то фантазийным причинам вдруг всё же хотите программировать MCU(шки), то старайтесь тогда угодить в компанию, где делают модульное тестирование сорцов, собирают из скриптов (Make файлов), делают отладку через CLI, есть командная работа (3+ вкладчика), практикуется пере использование кодовой базы, где фигурирует такое слова как AUTOSAR, CI/CD, есть планерки, инспекция программ, автосборки. И крайне важно, чтобы в компании полностью отсутствовала секретность на схемотехнику, datasheet(ы) и техническое задание. Там хотя бы будет выше вероятность сделать хоть что-то по-настоящему ценное.
В общем, делайте правильный выбор!
Словарь
Акроним | Расшифровка |
MK / MCU | Микроконтроллер |
CI | Continuous Integration |
ОКРы | опытно-конструкторские работы |
EMC | Электромагнитная совместимость |
Links/URLs
Разработчики встраиваемых систем не умеют программировать https://habr.com/ru/post/555498/
Градация Навыков в Embedded Программировании https://habr.com/ru/articles/725156/
Изготовление Макета для Прототипа https://habr.com/ru/articles/709932/
Вы точно хотите пойти программистом в gamedev? https://habr.com/ru/articles/774972/
Кто такой embedded-программист (разработчик) и как им стать https://dzen.ru/a/YuijxdVJz03-ohId