ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [devel] kernel packagin', new generation
@ 2003-02-17 22:34 Peter Novodvorsky
  2003-02-17 21:50 ` Volkov Serge
                   ` (4 more replies)
  0 siblings, 5 replies; 18+ messages in thread
From: Peter Novodvorsky @ 2003-02-17 22:34 UTC (permalink / raw)
  To: devel

Здравствуйте!

Я занимаюсь созданием новых пакетов с ядром. Поговорив в ldv, rider и
другими участниками команды мои планы по проектированию новых спеков
для ядра более-менее устаканились и я вам их и представляю.

При проектировании спека мной преследовались следующие три цели, две
конкретные и одна более абстракная:

  * Из одного spec-файла генерируется не больше одного пакета с
  образом ядра.
  * Все, что может собираться отдельно от ядра, собирается отдельно.
  * Пакет с ядром должен собираться из конструктора, из маленьких
  кусочков, причем сборка нового вида ядра не должна быть запутанным
  процессом.

Я предлагаю следующую инфраструктуру. Тарболы с исходными файлами
kernel, alsa, drm, pcmcia-cs, etc., собираются в отдельные
пакеты. Патчи тоже. Со следующей стркутурой:

kernel-source RPM:
/usr/src/kernel-source-%{version}.tar.bz2
/usr/share/kspec-tmpl/kernel-source-%{version}.spec.tmpl

alsa RPM:
/usr/src/alsa-%{version}.tar.bz2
/usr/share/kspec-tmpl/alsa-%{version}.spec.tmpl


%{patch_name}-kernel-patch RPM:
/usr/src/patches/%{patch_name}/*  /* various patch files */
/usr/src/patches/apply/%{patch_name}

Планируется сделать скрипт make-kspec. make-kspec подставляет
переменные в начало spec.tmpl'ей и генерит спеки к заданным
пакетам. Например, 

make-kspec --kver 2.4.18 --modules alsa,drm,pcmcia-cs \
           --patches grsec,reiserfs --flavour multimedia \
           --release alt1

Оно генерит четыре спека, -- для ядра, и для трех модулей определяя в
них соответствующие требующиеся переменные. Далее, как происходит
работа с патчами: для спека ядра заполняется переменная %patches,
которая будет равна аргументу --patches. В спеке, в секции %prep есть
примерно следующее

local applied_patches;

tar -jxvf %kernel_tarball
pushd kernel-source-%{kversion}
for i in `echo %patches | sed -e 's/,/\ /g'`; do
  applied_patches="$applied_patches,$i"
  %patches_dir/apply/$i --kver %{kversion} --already-applied $applied_patches
done

Из этого спека будет генерится пакет kernel-image-2.4.18-multimedia
с версией 2.4.18 и версией релиза alt1 и
kernel-headers-2.4.18-multimedia с той же версией и той же версией
релиза.

Из соответствующих модулей будут генерится:
{alsa,drm,pcmcia-cs}-2.4.18-multimedia с соответствующей версией
{alsa,drm,pcmcia-cs}  и номером релиза alt1, которые будут зависеть от
kernel-headers-2.4.18-multimedia.

Единственная проблема, которая приходит мне в голову: патчи могут
конфликтовать. Но на этот случай пакет %{name}-kernel-patch может
иметь разные варианты патчей и реагировать на аргумент
--already-applied по ситуации.


Критика желательна. Просто необходима. А так же желательно согласие по
принципиальным вопросам. :)

-- 
Peter Novodvorsky                             nidd@myxomop.com
   http://people.altlinux.ru/~nidd   Deadheads, unite!
           Kill 'em all, and let God sort 'em out


^ permalink raw reply	[flat|nested] 18+ messages in thread

end of thread, other threads:[~2003-02-20  0:21 UTC | newest]

Thread overview: 18+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2003-02-17 22:34 [devel] kernel packagin', new generation Peter Novodvorsky
2003-02-17 21:50 ` Volkov Serge
2003-02-18  8:49 ` Alexander Bokovoy
2003-02-18  8:54 ` Alexey V. Lubimov
2003-02-18  9:48 ` Albert R. Valiev
2003-02-18 14:43   ` Peter Novodvorsky
2003-02-18 11:46     ` Aleksey Novodvorsky
2003-02-19  9:04     ` rider
2003-02-18 14:46 ` [devel] " Alexey Tourbin
2003-02-18 18:09   ` Peter Novodvorsky
2003-02-18 15:31     ` Alexey Tourbin
2003-02-18 18:44       ` Peter Novodvorsky
2003-02-18 16:00         ` Alexey Tourbin
2003-02-19  9:13     ` rider
2003-02-19 14:23       ` Peter Novodvorsky
2003-02-19 11:52         ` Denis Ovsienko
2003-02-19 15:00           ` Peter Novodvorsky
2003-02-20  0:21         ` Mikhail Zabaluev

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