14 декабря | 2017г. | 22:03:21

АвторТема: Разработка под Enigma2 на C/C++  (Прочитано 7942 раз)

0 Пользователей и 1 Гость смотрят эту тему.

Оффлайн StuartАвтор темы

  • Джедай Куратор
  • **
  • Сообщений: 416
  • Поблагодарили: 1023
На фоне одной из моих раннее созданных тем по поводу компиляции драйверов WiFi "свистка" под спутниковые ресиверы, меня частенько "долбят" в аську/личку с вопросами "а как"?  ;) Основной из которых - чем и как собирать, с остальным вроде как Google ещё в силах помочь.

Так вот большая часть как плагинов, так и схем оформлений (иначе "скинов") под Enigma2 написана на языке программирования Python. Однако для тех, у кого нет времени или просто не видит смысла на освоение достаточно простого скриптового языка, но на "ты" с C или/и C++ и тем более Linux, тоже может внести свою лепту в развитие Enigma2. Это и полное управление операционной системой, и компиляция драйверов, например, для новых чипсетов WiFi-адаптеров, и, наконец-то, та же доработка/разработка эмуляторов.  :bye:

Однако, как известно, нативной аппаратной платформой, под которую Enigma2 изначально разрабатывалась - процессоры Broadcom, а точнее mipsel-архитектура. Что явно отличается от наших десктопов, а значит нужны компиляторы под конечную платформу, которые, как оказалось, не так уж и просто достать. Поэтому обсуждение этой темы хотелось бы как раз и начать с кросскомпиляторов. Дальнейшие вопросы - по мере поступления (постараюсь по возможности и знаниям поддерживать топик в актуальном состоянии).

Итак, наиболее простой вариант - скачать готовый тулчейн. Вполне неплохой вариант выложен на сайте oscam.

Однако он имеет древний компилятор gcc 4.3.2 аж 6-ти летней давности. Остальное подавляющее большинство тулчейнов либо рассчитано под архитектуру mips (которая, в отличие от mipsel имеет обратный порядок байт (big endian), применяемый чаще в сетях, а значит и в роутерах, под которые этим сами тулчейны и выложены), либо рассчитаны под С библиотеку uclibc, что нам тоже вроде как не совсем подходит (по крайней мере, в OpenPLi по умолчанию установлена libc, кстати последней на сегодня версии 2.19).

Поэтому выход только один - собирать тулчейн самому.

Самый простой вариант, для тех, у кого установлен "friendly-user linux", вроде ubuntu, - использовать утилиту crosstool-ng. Кратко, как собрать нужный нам тулчейн в Ubuntu.

Качаем нужные библиотеки:

Вам не разрешен просмотр кода. Войдите или Зарегистрируйтесь для просмотра.
Получаем последнюю стабильную версию с сайта (svn у меня даже не собирался), распаковываем, переходим в папку с исходниками и собираем:

Вам не разрешен просмотр кода. Войдите или Зарегистрируйтесь для просмотра.
Далее копируем готовый образец конфига под нашу архитектуру (так же имеется вариант под sh4-процессоры):

Вам не разрешен просмотр кода. Войдите или Зарегистрируйтесь для просмотра.
Можно просмотреть более подробные настройки через утилиту конфигурирования (как в ядре Linux) командой:

Вам не разрешен просмотр кода. Войдите или Зарегистрируйтесь для просмотра.
Особое внимание обратите на платформу - mipsel и порядок байт little endian, ну и libc. Можно поставить флажок экспериментальных версий, однако ничего из них почти не собирается. :)

Ну, и запускаем на компиляцию:

Вам не разрешен просмотр кода. Войдите или Зарегистрируйтесь для просмотра.
Где - 4 число процессов сборки (для систем с многоядерными процессорами).

В процессе подготовки могут быть ошибки при скачивании архивов. Не отчаиваемся - гуглим по имени и кидаем в ./build/tarballs. Так же в процессе сборки могут появляться ошибки компила. :) Опять-таки не расстраиваемся, а смотрим логи и исправляем (ещё более простой вариант - пробуем другую версию нужных либ, причём вписывать их можно непосредственно в .config-файл и разыскивая их в том же интернете).

Кому-таки собирать лень, может скачать мою сборку: ссылка на скачивание. В архиве присутствует лог сборки с полным конфиг-файлом, на котором удалось собрать gcc 4.4.7 с libc 2.11 и последними binutils 2.24. Как при помощи этого тулчейна собрать, например, тот же oscam, пример "how to" указан на их wiki (скиньте кстати им ссылку на более свежий тулчейн).

Собрать с более свежей версией gcc никак не получалось, так как на отказ не хотели собираться, то Cloog, то PPL.

Для тех же красноглазиков, которые не любят лёгких путей, и предпочитает полностью открытый софт, а так же всё самое свежее - неплохой вариант собирать ваши модули в Gentoo:acute: Делать это даже проще, чем кажется. Устанавливаем Gentoo по этой инструкции.

Уже в Gentoo устанавливаем crossdev:

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

Вам не разрешен просмотр кода. Войдите или Зарегистрируйтесь для просмотра.
Опять-таки имеются варианты под sh4-процессоры.

Устанавливаются актуальные хедеры ядра linux, компиляторов и библиотек. Например, вчера собрался тулчейн с gcc 4.8.2, libc 2.18, binutils 2.24 и kernel 3.12.13. С флагом -v можно указывать конкретные версии библиотек, например

Вам не разрешен просмотр кода. Войдите или Зарегистрируйтесь для просмотра.
По пути /etc/portage/make.conf

Добавляем строки следующего содержания:

Вам не разрешен просмотр кода. Войдите или Зарегистрируйтесь для просмотра.
Уже можем собирать нужные нам библиотеки. Например, для сборки openssl:

Вам не разрешен просмотр кода. Войдите или Зарегистрируйтесь для просмотра.
Переходим в каталог с распакованными "сорцами" и

Вам не разрешен просмотр кода. Войдите или Зарегистрируйтесь для просмотра.
Аналогично собираем, например, oscam (последнюю версию забираем с svn):

Вам не разрешен просмотр кода. Войдите или Зарегистрируйтесь для просмотра.
Перед сборкой можем указать флаги оптимизации под конкретную платформу/процессор, что может дать неплохую прибавку к производительности. Для Vu+ Solo кроме стандартных флагов оптимизации из makefile'а в виде -O2 и -pipe добавил -mips32r2 -mtune=mips32r2 -fno-caller-saves. По этому поводу более подробно уже гуглим самостоятельно по запросу "mipsel safe cflags".

Vitaliy69

Оффлайн StuartАвтор темы

  • Джедай Куратор
  • **
  • Сообщений: 416
  • Поблагодарили: 1023
Разработка под Enigma2 на C/C++
« Ответ #1: 05 мая | 2014г. | 18:40:03 »
Небольшое сообщение FAQ по вопросам, которые иногда задают в "аську".

Главный вопрос - где же сам API C/C++ для разработки под Enigma2. Если вкратце, то Enigma2 - это GUI-приложение, работающее на операционной системе Linux и ориентированное на STB (set-top-boxes). Фактически её можно запустить на персональном компьютере. Написана на Python с ядром, разработанным на C/C++ и использующая LinuxTV DVB API. Последняя является стандартной частью любого ядра Linux, полностью открыта, то есть дорабатывается сообществом по всему миру, и задокументирована. Текущая версия - 3.3 (помните, что для наших приставок в Wicardd приходится указывать DVBAPI3?). Фактически это и есть те самые API  C/C++ для разработки на приставки на базе MIPSEL BROADCOM процессоров, на котором функционирует Enigma2. Вы можете непосредственно управлять DVB-частью приставки (аудио и видеопотоки и пр.), для взаимодействия с Enigma2 - вам в другой раздел разработки плагинов на Python.

Ещё звучали вопросы про STAPI. Фактически это "DVBAPI" для SH4-приставок, например, "фортисов" и "октагонов". В отличие от DVD API, они закрыты, и поставляются STMicroelectronics только оплаченные лицензией библиотеки и include-файлы. Именно поэтому их практически невозможно найти в паблике, а разработчики приставок предоставляют так называемый Middleware-уровень, на основе которого можно разрабатывать плагины. Кстати, если кому нужен, то самый свежий Fortis API v1.20 вложил в сообщение.

Подробнее про STAPI можно почитать здесь. Разумеется, STAPI отличается от DVD API, именно поэтому по-разному работают эмуляторы и отличается "картинка". По поводу того, какая платформа лучше, согласен с данным сообщение:

Цитировать
так как STI проц с его вагоном ограничений и костылей в STAPI(SDK) + STLinux и потянет(потянул уже) весь этот проект ко дну, и рекламой и пиаром не решить к сожалению фундаментальных проблем STI как платформы.
За такие деньги должны быть фичи работающие как звонок, те идеально чтобы пытаться себя абстрагировать от E2 например.
А с STI это невозможно. STAPI(SDK родом с ртос ресов mpeg2) STlinux порождение STI, проц ST40 уникальный - всё это тупик в развитии признанный самим STI.
Развивать платформу STI сам не в состоянии - пытается уже который год перейти на ARM но безуспешно пока. Писано переписано о STI и его нерешабельных проблемах много(сеть и тп), нечего повторяться. В своё время AMINO добился от STI открыть им доку на процессоры и STAPI полностью(ну почти), убил пару тройку лет на переписывание всего говнокода STAPI ну и что кончилось тем что STI поменял API к фирмваре в след чипах и всё куку. В общем STI - ужос это, для простых запперов да, но не для "ГРАНДОВ" в смысле топов.

Для написания под SH4 так же нужен кросскомпилятор. Можно использовать Gentoo crossdev, описанный выше, или достаточно поставить STLinux (качаем скрипт и запускаем в консоли ./install all-sh4-glibc, в openSUSE мне ещё пришлось указать флаг -x, фактически ставиться тулчейн для кросс-компиляции).
Vitaliy69

Оффлайн StuartАвтор темы

  • Джедай Куратор
  • **
  • Сообщений: 416
  • Поблагодарили: 1023
Разработка под Enigma2 на C/C++
« Ответ #2: 27 июня | 2015г. | 22:21:58 »
Если у кого возникают проблемы с самостоятельно сборкой тулчейнов, выкладываю свои.

sh4 - gcc 4.9.2, glibc 2.19
mipsel - gcc 4.9.2, glibc 2.19
arm - gcc 4.8.4, glibc 2.13

Скачать
Vitaliy69

Онлайн vip1131

  • Друзья Джедаев
  • *****
  • Сообщений: 171
  • Поблагодарили: 922
Разработка под Enigma2 на C/C++
« Ответ #3: 27 ноября | 2015г. | 07:28:43 »
Собрано в crosstool-ng 1.22.0
sh4 - gcc 4.9.3, binutils 2.25.1, glibc 2.22

Скачать

Онлайн vip1131

  • Друзья Джедаев
  • *****
  • Сообщений: 171
  • Поблагодарили: 922
Разработка под Enigma2 на C/C++
« Ответ #4: 11 мая | 2016г. | 19:27:14 »
Toolchain Vu+ Solo4k
Для 32-битной системы...
Скачать

Онлайн vip1131

  • Друзья Джедаев
  • *****
  • Сообщений: 171
  • Поблагодарили: 922
Разработка под Enigma2 на C/C++
« Ответ #5: 05 апреля | 2017г. | 11:05:23 »
Новая версия среды сборки тулчейнов (нестабильная).

Онлайн vip1131

  • Друзья Джедаев
  • *****
  • Сообщений: 171
  • Поблагодарили: 922
Разработка под Enigma2 на C/C++
« Ответ #6: 27 июня | 2017г. | 09:59:22 »
Тулчейн для ресиверов на АРМ архитектуре, последний gcc 7.1.1
gcc-linaro-7.1.1-2017.05-x86_64_arm-linux-gnueabihf

Теги:
 

Похожие темы

  Тема / Автор Ответов Последний ответ
1047 Ответов
208626 Просмотров
Последний ответ 30 августа | 2017г. | 22:09:17
от yuju
168 Ответов
19837 Просмотров
Последний ответ 15 августа | 2014г. | 13:19:22
от android
Enigma2: PLi max-tdt

Автор vardan85 « 1 2 ... 49 50 » Enigma2

744 Ответов
161372 Просмотров
Последний ответ 16 апреля | 2014г. | 10:51:37
от vardan85
0 Ответов
3 Просмотров
Последний ответ 17 марта | 2014г. | 22:00:30
от 2boom
5 Ответов
3699 Просмотров
Последний ответ 15 октября | 2016г. | 17:54:14
от Stuart



X

Добро пожаловать!

Мы заметили, что у Вас установлено расширение AdBlock или ему подобное. Пожалуйста добавьте наш Клуб в белый список, внесите этим посильную лепту в его развитие. Спасибо!