А так как патенты в западных странах на Эльбрус[103] не оформлялись, и на его архитектуру и составные узлы также. То они ещё и могут заявлять, что производимые раньше их патентов Эльбрусы — были нарушающими их законные права.
Впрочем, моё мнение о патентном праве однозначное. На данном этапе оно является тормозом научно-технического прогресса и кормушкой для жадных адвокатов. Бесконечные патентные войны между корпорациями, тому ярчайший пример.
Не нужно нам таких Пентковских. Понятно, что не от хорошей жизни и отменного финансирования проектов он подался из ельцинской России в США. Но это не меняет положения вещей, и огромные средства, затраченные на разработку советским государством, перекочевали за океан.
Лучше уж без таких обойдёмся. Но это вовсе не означает, что не добавится много иных проблем. И большинство из них, вполне ожидаемо. Новые люди ознакомились с проектом, и появились заумные вопросы и предложения. Мне начали выносить мозг с интерфейсами.
Все они привыкли к параллельным угрёбищам, а я волевым решением оставил только последовательные. Меня сразу стали критиковать, что параллельные проще в реализации и более производительны, а на последовательных никогда не достичь нужной скорости передачи. В этом они сильно таки погорячились, так как сегодняшние последовательные шины достигли огромной пропускной способности.
Для своего времени они наверно правы, но я-то знаю, что параллельные интерфейсы «must die!» И приговорил их в превентивном порядке. Нечего городить чепуху и тратить силы и средства на их разработку, а затем доводку и модернизацию. Пусть этим амеры балуются. Чем дольше будут, тем лучше, а «мы пойдем другим путём». Тем более, что организацию последовательных и параллельных я знаю досконально, вплоть до винтика. Приходилось в приборах подсоединять разные датчики и блоки, и связывать всё по ним. SPI, I2C, JTAG и USB[104] — ночью после побудки расскажу не запинаясь и полную аппаратную реализацию также.
Приходилось самому городить, если в чипе не оказывалось хоть одного из них. Сначала собирал из стандартных микросхем, а позднее стал просто вносить в проект заливки в ПЛИС[105] и реализовывал там. При этом проектировал не только на языках — Verilog, VHDL, но и прорисовывал в схемном виде.
А последовательную шину USB реализовывал на базе проектируемого микроконтроллера Atmel AVR. Для этого пришлось досконально изучить систему команд этого микроконтроллера и язык ассемблера. Однако не только повторял то, что сделали до меня, но и реализовал более полную проверку ошибок шины, согласно спецификации на неё.
На тот момент уже имел достаточный опыт работы с микроконтроллерами, включающими аппаратную реализацию этой шины. Но они не везде были удобны, и зачастую избыточны.
Это позволяло мне сливать данные в компьютер по стандартной шине, и не устраивать пляску с бубнами — разрабатывая драйвера. Так как можно было использовать стандартный HID-драйвер[106]. Скорость маловата для некоторых задач, но слить результаты измерений за несколько минут вполне возможно.
Но затраченное тогда время и усилия, сейчас дают неоспоримые преимущества, для собственной разработки и внедрения. Я совсем не чета здешним гениям. У них у всех красные дипломы, и аспирантуры с кандидатскими, и даже докторскими. И тем более, не чета самому Виктору Михайловичу.
Сам в институте учился нормально, а по некоторым предметам лучше прочих, но проповедовал принцип: — «Лучше иметь красную рожу и синий диплом, чем синюю рожу и красный диплом». Частенько загорал на пляжах и не был зубрилкой, а предпочитал ходить нехожеными тропами.
На дипломе оббегал весь институт и не мог найти руководителя дипломного проектирования. Проработал принципиальную электрическую схему — микропроцессорной системы на только с пылу с жару уворованном — I8080, написал программу и прорисовал периферийные устройства собственной разработки. А в институте ни один преподаватель не знал, что это за зверь, и с чем его едят. Одни отговаривались, что у них стоит в планах изучать его к концу следующего учебного года. Другие и слушать не хотели, а предлагали стандартный дипломный проект, защищаемый студентами десятилетия.
103
— В ИТМиВТ Владимир Пентковский принимал участие в разработке суперкомпьютеров Эльбрус-1 (1978) и Эльбрус-2 (1984). В 1986 году он возглавил проект 32-разрядного микропроцессора Эль-90. К 1987 году логический дизайн будущего микропроцессора был завершен, а в 1990 г произведены первые прототипы. В Эль-90 сочетались концепция RISC и архитектура Эльбрус-2. Но после изменения в России политической и экономической системы, финансирование разработки прекратилось. Спасибо нашим эффективным манагерам. И все было реализовано в процессоре «Pentium» и последующих и сэкономило фирме «Intel» миллиарды долларов.
104
— Интерфейс SPI (Serial Peripheral Interface), — трехпроводный синхронный с раздельными линиями входных и выходных данных — применяется для связи микроконтроллеров с периферийными микросхемами и микросхемами памяти.
Интерфейс І2C, — двухпроводный синхронный с общей линией входных и выходных данных Спецификация шины І2С определяет протокол двусторонней передачи данных по двум сигнальным линиям.
Интерфейс JTAG(Joint Test Action Group), — предназначен для тестирования сложных логических схем, установленных в целевое устройство.
Шина USB (Universal Serial Bus), — последовательный интерфейс для подключения периферийных устройств к вычислительной технике. Получил широчайшее распространение и стал основным интерфейсом подключения периферии к бытовой цифровой технике.
105
— Программируемая логическая интегральная схема (ПЛИС, англ. programmable logic device, PLD) — электронный компонент (интегральная микросхема), используемый для создания конфигурируемых цифровых электронных схем. В отличие от обычных цифровых микросхем, логика работы ПЛИС не определяется при изготовлении, а задаётся посредством программирования (проектирования). Для программирования используются программатор и IDE (отладочная среда), позволяющие задать желаемую структуру цифрового устройства в виде принципиальной электрической схемы или программы на специальных языках описания аппаратуры: Verilog, VHDL, AHDL и др.
106
— USB HID (human interface device) class — класс устройств USB для взаимодействия с человеком. Этот класс включает в себя такие устройства как клавиатура, мышь, игровой контроллер. Класс USB HID определен в нескольких документах, предоставляемых USB Implementers Forum. Работают со стандартным драйвером.