From: Ildar Mulyukov <ildar@altlinux.ru> To: ALT Devel discussion list <devel@lists.altlinux.org> Subject: [devel] использование сборочных возможностей RPM для кросс-компиляции/сборки (прежде: I: x86_64 update) Date: Tue, 18 Jul 2006 14:31:07 +0600 Message-ID: <1153211467l.6830l.1l@ildar.nexttel.kz> (raw) Здравствуйте, Есть идея, несколько мыслей и вопросы. Всё довольно не систематично, я предупредил! Постановка задачи: хочется создать среду для прозрачной кросс-сборки _некоторых_ программ (в пакетах) для "чуждой" платформы (в моём случае это XScale-linux (familiar). Предпосылки: у rpm есть ключ --target, который может прозрачно передаваться макросу %make_build Предположительно, как это можно сделать: Подпилить rpm-build, чтобы для нужных архитектур находились макросы и использовались нужные binutils. Создать пакет(ы) rpm-build-cross-{arch,...} с зависимостями на соотв. кросс-средства. Также хорошо бы создать информационную страничку (wiki на freesource.info?) для сбора информации о предмете. Поиск: поворошив архивы альтлинукса на тему кросс-компиляции, наткнулся на след. письмо - http://lists.altlinux.org/pipermail/devel/2005-February/018012.html Судя по нему, для замысла есть непреодолимые трудности (?) Если возможно, хотелось бы получить комментарии (в т.ч. от mouse@) > [devel] I: x86_64 update > Anton D. Kachalov mouse на altlinux.org > Чт Фев 3 12:27:33 MSK 2005 > > On Thu, Feb 03, 2005 at 11:44:45AM +0300, Vitaly Lipatov wrote: > > > именно только на x86_64 , кросскомпилинг страшная и невсегда > > > работающая штука > > Не вижу объективных причин. Мне кажется, как к нему относишься, > > так он и работает. А основная причина может в том, что мысли о > > том, что в Сизифе должен быть кросскомпилятор (кроме mingw) - > > нет. > кросс x86_64 (gcc3.3, а 3.4 я не пробовал) оооочень крив. Там нужно > было жуткое кол-во костылей вставлять, чтобы что-то собирать. > С ARM и MIPS такого секса я не ощущал, как с кроссом x86_64. > Нативная сборка всегда лучше, тем более, когда есть вычислительное > мощности. Одна из причин - это то, что хост среда отличается от > таргета. > Представляем себе некую прогу, которая говорит uname -m и > ориентируется на это. плохие проги! > А ещё есть проги (кривые), которые любят сначала собрать прогу, а > потом этой прогой заюзать для дальнейшей сборки. Бывает, но не так часто. > Опять же, кроссовые либы живут не в /usr/lib/, а в /usr/arch/usr/lib. Этот вопрос рано или поздно надо решать. Как решать - по этому поводу надо собрать информацию и положить в wiki > И опять вспоминаем какие-нить проги, которые тож жёстко к этому > привязываются. А ещё... хорошо, я понимаю автора (mouse), который исходил из самого общего случая. Думаю, что программ, для которых изначально предусмотрена кросс-платформенная сборка, эти проблемы не касаются. (я, в частности, хочу собрать насколько таких программ) > И самое главное - как вы себе представляете сборку пакетов под другу > архитектуру кроссом из того же спека? (С учётом устанавливаемых > пакетов в собираемую среду). Вот тут мне не понятно, в чём трудность. Есть предположения? Конечно, с текущей версией rpm-build это невозможно. > И ещё, тот же rpm не позволит поставить пакет другой архитектуры, > если ему не написать, что i586 совместим с x86_64 - бред > же. А.. вот это надо как-то обойти. Возможно, имеет смысл отдельное дерево (/usr/arch?) со своим %archprefix/var/lib/rpm/Packages и плясками c rpm-build. Тут надо крепко подумать и воплотить в rpm-%version.src.rpm > Т.ч.наличие кросса avr и mingw - всего-лишь необходимость в сборке > под девайсы (avr), на которых просто нереально что-либо собирать :)) > а mingw я тож пользуюсь, но пакеты ж не собираю...и вроде пока никто > не устраивает (и не собирался вроде) отдельного cygwin-репозитария. Ну почему же? Мне было бы интересно. Всё написанное предлагается к обсуждению. Если это неуместно, я готов смиренно перейти в другой список рассылки. С уважением, Ильдар. -- Ildar Mulyukov, free SW designer/programmer/packager ========================================= email: ildar@altlinux.ru ALT Linux Sisyphus http://www.sisyphus.ru =========================================
next reply other threads:[~2006-07-18 8:31 UTC|newest] Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top 2006-07-18 8:31 Ildar Mulyukov [this message] 2006-07-18 8:48 ` Grigory Batalov
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=1153211467l.6830l.1l@ildar.nexttel.kz \ --to=ildar@altlinux.ru \ --cc=devel@lists.altlinux.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
ALT Linux Team development discussions This inbox may be cloned and mirrored by anyone: git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git # If you have public-inbox 1.1+ installed, you may # initialize and index your mirror using the following commands: public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \ devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru public-inbox-index devel Example config snippet for mirrors. Newsgroup available over NNTP: nntp://lore.altlinux.org/org.altlinux.lists.devel AGPL code for this site: git clone https://public-inbox.org/public-inbox.git