ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [devel] Сборка пакетов для armh/aarch64 в хэшере на хосте x86_64
  @ 2018-01-19  9:18 ` Alexei Takaseev
  2018-01-20 14:10   ` Антон Мидюков
                     ` (2 more replies)
  0 siblings, 3 replies; 5+ messages in thread
From: Alexei Takaseev @ 2018-01-19  9:18 UTC (permalink / raw)
  To: ALT Linux Team development discussions

Добрый день!

Пытаюсь по инструкции с https://www.altlinux.org/Ports/arm/BuildHowto наладить
у себя сборку своих пакетов под архитектуры armh/aarch64 (в рамках объявленной
в скором будущем обязательности поддержки этих платформ), но что-то не выходит
каменный цветок.

По инструкции прописал /proc/sys/fs/binfmt_misc (кстати, там нет данных под
aarch64), далее создал каталоги /mnt/DISK/virtuals/{aarch64,armh}, в них положил
apt.conf такого содержания:

Dir::Etc::SourceList "/mnt/DISK/virtuals/{armh|aarch64}/sources.list";
Dir::Etc::SourceParts "/var/empty";
Dir::Etc::main "/dev/null";
Dir::Etc::parts "/var/empty";

И файлы sources.list:

rpm file:/mnt/sdc5/Sisyphus armh classic
...
rpm file:/mnt/sdc5/Sisyphus aarch64 classic

Но при попытке запуска инициализации хэшера получаю такое:

$ hsh --with-qemu=arm --target=armh --apt-config=/mnt/DISK/virtuals/armh/apt.conf /mnt/DISK/virtuals/armh --initroot-only
Чтение списков пакетов...
Построение дерева зависимостей...
Пакет setup присутствует в базе данных, но не имеет доступной версии.
Как правило это означает, что хотя пакет упоминается в списке зависимостей,
он отсутствует в репозитории, был вытеснен, либо в sources.list нет адреса
репози�E: Для пакета setup не найдено подходящего кандидата для установки
hsh-initroot: Failed to calculate package file list.
hsh-initroot: Failed to generate initial package file list.

Такое ощущение, что apt игнорирует пакеты noarch в репозитории. Как это можно победить?

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

* Re: [devel] Сборка пакетов для armh/aarch64 в хэшере на хосте x86_64
  2018-01-19  9:18 ` [devel] Сборка пакетов для armh/aarch64 в хэшере на хосте x86_64 Alexei Takaseev
@ 2018-01-20 14:10   ` Антон Мидюков
  2018-01-22 20:27   ` Michael Shigorin
  2018-01-26 12:25   ` Sergey Bolshakov
  2 siblings, 0 replies; 5+ messages in thread
From: Антон Мидюков @ 2018-01-20 14:10 UTC (permalink / raw)
  To: devel

19.01.2018 16:18, Alexei Takaseev пишет:
> ...
>
> Но при попытке запуска инициализации хэшера получаю такое:
>
> $ hsh --with-qemu=arm --target=armh --apt-config=/mnt/DISK/virtuals/armh/apt.conf /mnt/DISK/virtuals/armh --initroot-only
> Чтение списков пакетов...
> Построение дерева зависимостей...
> Пакет setup присутствует в базе данных, но не имеет доступной версии.
> Как правило это означает, что хотя пакет упоминается в списке зависимостей,
> он отсутствует в репозитории, был вытеснен, либо в sources.list нет адреса
> репози�E: Для пакета setup не найдено подходящего кандидата для установки
> hsh-initroot: Failed to calculate package file list.
> hsh-initroot: Failed to generate initial package file list.
>
> Такое ощущение, что apt игнорирует пакеты noarch в репозитории. Как это можно победить?
Попробовал у себя по инструкции этой так сделать, такая же ошибка. 
Пробовал noarch подключать, эффект тот же.

-- 
С уважением, Антон Мидюков <antohami@altlinux.org>



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

* Re: [devel] Сборка пакетов для armh/aarch64 в хэшере на хосте x86_64
  2018-01-19  9:18 ` [devel] Сборка пакетов для armh/aarch64 в хэшере на хосте x86_64 Alexei Takaseev
  2018-01-20 14:10   ` Антон Мидюков
@ 2018-01-22 20:27   ` Michael Shigorin
  2018-01-26 12:25   ` Sergey Bolshakov
  2 siblings, 0 replies; 5+ messages in thread
From: Michael Shigorin @ 2018-01-22 20:27 UTC (permalink / raw)
  To: devel

On Fri, Jan 19, 2018 at 05:18:37PM +0800, Alexei Takaseev wrote:
> Пытаюсь по инструкции с https://www.altlinux.org/Ports/arm/BuildHowto наладить
> у себя сборку своих пакетов под архитектуры armh/aarch64 (в рамках объявленной
> в скором будущем обязательности поддержки этих платформ), но что-то не выходит
> каменный цветок.

Возможно, изменилось то, что получается в `uname -m` --
несколько лет назад работало, собирал таким макаром образы
armh и ppc в mkimage-profiles вдобавок к "родным" таким же.

> По инструкции прописал /proc/sys/fs/binfmt_misc
> (кстати, там нет данных под aarch64)

Добавьте?

> Такое ощущение, что apt игнорирует пакеты noarch в репозитории.
> Как это можно победить?

Чисто на всякий: они там (в индексах) точно есть?

-- 
 ---- WBR, Michael Shigorin / http://altlinux.org
  ------ http://opennet.ru / http://anna-news.info


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

* Re: [devel] Сборка пакетов для armh/aarch64 в хэшере на хосте  x86_64
  2018-01-19  9:18 ` [devel] Сборка пакетов для armh/aarch64 в хэшере на хосте x86_64 Alexei Takaseev
  2018-01-20 14:10   ` Антон Мидюков
  2018-01-22 20:27   ` Michael Shigorin
@ 2018-01-26 12:25   ` Sergey Bolshakov
  2018-01-29 10:20     ` Alexei Takaseev
  2 siblings, 1 reply; 5+ messages in thread
From: Sergey Bolshakov @ 2018-01-26 12:25 UTC (permalink / raw)
  To: devel

[-- Attachment #1: Type: text/plain, Size: 898 bytes --]

>>>>> "Alexei" == Alexei Takaseev <alexei-W/DNgjy8krs@public.gmane.org> writes:

 > Добрый день!
 > Пытаюсь по инструкции с https://www.altlinux.org/Ports/arm/BuildHowto наладить
 > у себя сборку своих пакетов под архитектуры armh/aarch64 (в рамках объявленной
 > в скором будущем обязательности поддержки этих платформ), но что-то не выходит
 > каменный цветок.

 > По инструкции прописал /proc/sys/fs/binfmt_misc (кстати, там нет данных под
 > aarch64), далее создал каталоги /mnt/DISK/virtuals/{aarch64,armh}, в них положил
 > apt.conf такого содержания:

У меня в /etc/binfmt.d/ есть два таких вот:


[-- Attachment #2: qemu-aarch64-static.conf --]
[-- Type: text/plain, Size: 205 bytes --]

:aarch64:M::\x7f\x45\x4c\x46\x02\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02\x00\xb7\x00:\xff\xff\xff\xff\xff\xff\xff\x00\xff\xff\xff\xff\xff\xff\xff\xff\xfe\xff\xff\xff:/usr/bin/qemu-aarch64.static:F

[-- Attachment #3: qemu-armh-static.conf --]
[-- Type: text/plain, Size: 190 bytes --]

:armh:M::\x7fELF\x01\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02\x00\x28\x00:\xff\xff\xff\xff\xff\xff\xff\x00\xff\xff\xff\xff\xff\xff\xff\xff\xfe\xff\xff\xff:/usr/bin/qemu-armh.static:F

[-- Attachment #4: Type: text/plain, Size: 1362 bytes --]


При этом для ядер >= 4.8 становится ненужным указывать --with-qemu=

[skipped]

> Но при попытке запуска инициализации хэшера получаю такое:

 > $ hsh --with-qemu=arm --target=armh --apt-config=/mnt/DISK/virtuals/armh/apt.conf /mnt/DISK/virtuals/armh --initroot-only
 > Чтение списков пакетов...
 > Построение дерева зависимостей...
 > Пакет setup присутствует в базе данных, но не имеет доступной версии.
 > Как правило это означает, что хотя пакет упоминается в списке зависимостей,
 > он отсутствует в репозитории, был вытеснен, либо в sources.list нет адреса
 > репози�E: Для пакета setup не найдено подходящего кандидата для установки
 > hsh-initroot: Failed to calculate package file list.
 > hsh-initroot: Failed to generate initial package file list.

 > Такое ощущение, что apt игнорирует пакеты noarch в репозитории. Как
 > это можно победить?


echo 'arch_compat: x86_64: noarch' > ~/.rpmrc

или


[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #5: mkaptbox.diff --]
[-- Type: text/x-patch, Size: 423 bytes --]

--- /usr/bin/mkaptbox~	2017-11-22 08:04:18.000000000 +0300
+++ /usr/bin/mkaptbox	2018-01-26 15:12:19.818852241 +0300
@@ -216,7 +216,7 @@
 		[ ! -f "$f" ] ||
 			install -pm600 $verbose -- "$f" "$aptbox_home/" >&2
 	done
-	echo "arch_compat: $current_arch: ${target:-$def_target}" >> "$aptbox_home/.rpmrc"
+	echo "arch_compat: $current_arch: ${target:-$def_target} noarch" >> "$aptbox_home/.rpmrc"
 fi
 
 # create wrappers.

[-- Attachment #6: Type: text/plain, Size: 5 bytes --]


-- 

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

* Re: [devel] Сборка пакетов для armh/aarch64 в хэшере на хосте  x86_64
  2018-01-26 12:25   ` Sergey Bolshakov
@ 2018-01-29 10:20     ` Alexei Takaseev
  0 siblings, 0 replies; 5+ messages in thread
From: Alexei Takaseev @ 2018-01-29 10:20 UTC (permalink / raw)
  To: ALT Linux Team development discussions

[-- Attachment #1: Type: text/plain, Size: 3020 bytes --]



----- Исходное сообщение -----
> От: "Sergey Bolshakov" <sbolshakov@altlinux.ru>
> Кому: devel@lists.altlinux.org
> Отправлено: Пятница, 26 Январь 2018 г 20:25:31
> Тема: Re: [devel] Сборка пакетов для armh/aarch64 в хэшере на хосте  x86_64
> 
> >>>>> "Alexei" == Alexei Takaseev
> >>>>> <alexei-W/DNgjy8krs@public.gmane.org> writes:
> 
>  > Добрый день!
>  > Пытаюсь по инструкции с
>  > https://www.altlinux.org/Ports/arm/BuildHowto наладить
>  > у себя сборку своих пакетов под архитектуры armh/aarch64 (в рамках
>  > объявленной
>  > в скором будущем обязательности поддержки этих платформ), но
>  > что-то не выходит
>  > каменный цветок.
> 
>  > По инструкции прописал /proc/sys/fs/binfmt_misc (кстати, там нет
>  > данных под
>  > aarch64), далее создал каталоги /mnt/DISK/virtuals/{aarch64,armh},
>  > в них положил
>  > apt.conf такого содержания:
> 
> У меня в /etc/binfmt.d/ есть два таких вот:
> 
> При этом для ядер >= 4.8 становится ненужным указывать --with-qemu=

Спасибо, добавил.

> [skipped]
> 
> > Но при попытке запуска инициализации хэшера получаю такое:
> 
>  > $ hsh --with-qemu=arm --target=armh
>  > --apt-config=/mnt/DISK/virtuals/armh/apt.conf
>  > /mnt/DISK/virtuals/armh --initroot-only
>  > Чтение списков пакетов...
>  > Построение дерева зависимостей...
>  > Пакет setup присутствует в базе данных, но не имеет доступной
>  > версии.
>  > Как правило это означает, что хотя пакет упоминается в списке
>  > зависимостей,
>  > он отсутствует в репозитории, был вытеснен, либо в sources.list
>  > нет адреса
>  > репози�E: Для пакета setup не найдено подходящего кандидата для
>  > установки
>  > hsh-initroot: Failed to calculate package file list.
>  > hsh-initroot: Failed to generate initial package file list.
> 
>  > Такое ощущение, что apt игнорирует пакеты noarch в репозитории.
>  > Как
>  > это можно победить?
> 
> 
> echo 'arch_compat: x86_64: noarch' > ~/.rpmrc
> 
> или

Запустить получилось только после патча mkaptbox.

Скорость сборки у aarch64 оказалась ничем не отличной от сборки под
x86_64 и i586, а вот сборка armh это боль... очень долгая боль.

[-- Attachment #2: Type: text/x-patch, Size: 423 bytes --]

--- /usr/bin/mkaptbox~	2017-11-22 08:04:18.000000000 +0300
+++ /usr/bin/mkaptbox	2018-01-26 15:12:19.818852241 +0300
@@ -216,7 +216,7 @@
 		[ ! -f "$f" ] ||
 			install -pm600 $verbose -- "$f" "$aptbox_home/" >&2
 	done
-	echo "arch_compat: $current_arch: ${target:-$def_target}" >> "$aptbox_home/.rpmrc"
+	echo "arch_compat: $current_arch: ${target:-$def_target} noarch" >> "$aptbox_home/.rpmrc"
 fi
 
 # create wrappers.

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

end of thread, other threads:[~2018-01-29 10:20 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2018-01-19  9:18 ` [devel] Сборка пакетов для armh/aarch64 в хэшере на хосте x86_64 Alexei Takaseev
2018-01-20 14:10   ` Антон Мидюков
2018-01-22 20:27   ` Michael Shigorin
2018-01-26 12:25   ` Sergey Bolshakov
2018-01-29 10:20     ` Alexei Takaseev

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