[d-kernel] Q: разноплатформенные конфиги для kernel-image

Sergey Vlasov vsu на altlinux.ru
Сб Апр 16 21:07:28 MSD 2005


On Sat, Apr 16, 2005 at 07:13:04PM +0400, Anton D. Kachalov wrote:
> Поднимаю ещё раз вопрос о том, как быть со сборкой ядра из одного spec'а
> для разных архитектур?
> Могу предложить вариант, основанный на макросах.
> 
> 1. инклуд конфигов в спек:
> 
> %add_source_config i586
> %add_source_config athlon
> %add_source_config x86_64

Тут смешаны в одну кучу архитектура и оптимизация.  В принципе можно
собрать и 32-разрядное ядро с оптимизацией под Athlon-64 (CONFIG_MK8).
Да и у x86_64 сейчас есть CONFIG_MK8 (-march=k8) и CONFIG_MPSC
(-march=nocona).

> что должно добавить:
> SourceN: config-%kernel_base_version-%flavour.i586
> Source(N+1): config-%kernel_base_version-%flavour.athlon
> Source(N+2): config-%kernel_base_version-%flavour.x86_64
> 
> 2. секция build, копирование конфига
> 
> вместо %__cp -vf %SOURCE1 arch/%base_arch/defconfig используем:
> %copy_kernel_source_config
> 
> этот макрос должен сделать проверку на наличие конфига
> config-%kernel_base_version-%flavour.%base_arch и если есть, скопировать в
> arch/%base_arch/defconfig
> 
> Вопрос: что делать, если конфиг не найден? Т.е. если я решил собрать ядро
> с --target=i686 вместо --target=i586? Делать symlink'и на конфиги и
> паковать?

Ну в принципе можно попытаться и подкорректировать тип процессора в
конфиге.  Надо строить какую-то таблицу (%arch) -> (%base_arch,
CONFIG_Mxxx).  Правда, в разных версиях ядер набор доступных
CONFIG_Mxxx может быть разным, но можно писать туда несколько
вариантов.

#!/bin/sh

base_arch="$1"

cpu_types=$(sed -ne '/prompt[[:space:]]\+"Processor family"/,/endchoice/ s/^config[[:space:]]\+\([^[:space:]]\+\)[[:space:]]*$/\1/p' < arch/"$base_arch"/Kconfig)

filter=
for cpu in $cpu_types; do
	if [ "$cpu" = "$2" ]; then
		echo "CONFIG_$cpu=y"
	else
		echo "# CONFIG_$cpu is not set"
	fi
	filter="$filter
/CONFIG_$cpu[=[:space:]]/d"
done

sed -e "$filter"

(2.6.x only; ещё дописать подбор поддерживаемого ядром значения из
заданного набора).

> И мне немного неясен хак:
> ### It's a hack, but a useful hack:
> cmp -s .config %SOURCE1 || %__cp -vf .config %SOURCE1

Видимо, можно его убивать - сейчас в 2.6 это копирование выполняется
каждый раз, поскольку в .config положили timestamp.

Кстати, кто-нибудь помнит, почему конфиг кладётся в
arch/%base_arch/defconfig, а не в .config с последующим запуском make
oldconfig?

> Какие ещё могут быть варианты?
> 
> Со всем остальным проблем нет. Собирается на ура.
> Разумеется, перед релизом ядра, ответственные за архитектуры, обновляют
> конфиги :)
----------- следущая часть -----------
Было удалено вложение не в текстовом формате...
Имя     : отсутствует
Тип     : application/pgp-signature
Размер  : 189 байтов
Описание: отсутствует
Url     : http://lists.altlinux.ru/pipermail/devel-kernel/attachments/20050416/ef70c7bd/attachment.bin


Подробная информация о списке рассылки devel-kernel