ALT Linux Sisyphus discussions
 help / color / mirror / Atom feed
* [sisyphus] Re: Fwd: non-threaded perl (was: Зависимости пакетов и apt-get)
  @ 2005-06-02 17:42         ` Alexey Tourbin
    0 siblings, 1 reply; 2+ messages in thread
From: Alexey Tourbin @ 2005-06-02 17:42 UTC (permalink / raw)
  To: JoyLink; +Cc: Sisyphus

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

On Thu, Jun 02, 2005 at 07:16:29PM +0400, JoyLink wrote:
> Здравствуйте, Алексей.
> Насколько реально собрать non-threaded версию perl для ALM 2.4?
> Своими силами не получается :(

non-threaded сборка перла будет бинарно несовместима, т.е. придется
пересобрать также все пакеты, которые зависят от libperl.so.5.8.

Дело в том, что первый условный аргумент у всех функций из perl API/ABI --
это так называемый thread context.  Например,

av.c:Perl_av_len(pTHX_ register AV *av)

Здесь pTHX_ раскрывается либо в ничто (non-threaded), либо в настоящий
аргумент функции (threaded сборка перла).  Некоторые подробности есть в
perlguts.

То есть у "системного пакета" в данном случае менять флаги компиляции
крайне не рекомендуется.  Можно собрать самому "не системный" перл и
установить его в /usr/local.  Читайте INSTALL.

Интересно также узнать, в каких случаях может потребоваться именно
non-threaded perl.

> ---------- Пересылаемое письмо ----------
> От:                  Michael Shigorin <mike@osdn.org.ua>
> К:                   community@altlinux.ru
> А также к:           JoyLink <dicom@mail.ru>
> Время создания:      Tue, 31 May 2005 12:37:42 +0300
> Тема:                non-threaded perl (was: Зависимости пакетов и apt-get)
> Прикрепленные файлы: <none>
> 
> On Tue, May 31, 2005 at 10:23:30AM +0400, JoyLink wrote:
> > > Наверное проще взять готовый спек от перла и собрать с новыми
> > > исходниками. Если соберётся можете считать себя начинающим
> > > майнтейнером :)
> > Пытался. Не получилось. На самом деле нужна не threaded версия Perl
> 
> Свяжитесь с майнтейнером (at@) и обсудите, как лучше
> собрать такой вариант.  При помощи hasher на установленном
> (не разломанном) Master 2.4 это вполне можно сделать,
> если нет принципиальных грабель.
> 
> Обсуждения тредовости perl были, но помню просто как факт --
> бишь даже не туманно.
> 
> -- 
>  ---- WBR, Michael Shigorin <mike@altlinux.ru>
>   ------ Linux.Kiev http://www.linux.kiev.ua/
> 
> 
> ---------- Конец пересылаемого письма ----------

[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]

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

* [sisyphus] Re: Fwd: non-threaded perl (was: Зависимости пакетов и apt-get)
  @ 2005-06-04  1:02             ` Alexey Tourbin
  0 siblings, 0 replies; 2+ messages in thread
From: Alexey Tourbin @ 2005-06-04  1:02 UTC (permalink / raw)
  To: JoyLink; +Cc: Sisyphus

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

On Fri, Jun 03, 2005 at 11:09:00AM +0400, JoyLink wrote:
> > Интересно также узнать, в каких случаях может потребоваться именно
> > non-threaded perl.
> 
> Я достаточно давно использую это ПО http://www.icdevgroup.org для организации
> интернет-магазина (<snipped by at@altlinux>). Оно требует именно non-threaded perl
> (http://www.icdevgroup.org/interchange-doc-5.2.0/icfaq.html#Configuration%20Problems),
> хотя ситуация может измениться с выпуском новой версии.

Проблема в том, что в threaded perl используется специальный алгоритм
кэширования ppid для тредов, который не учитывает UNIX семантику
изменения ppid при смерти родительского процесса (значение ppid в этом
случае изменяется на 1, т.е. рипать осиротевших потомков будет процесс init).

Исправление для данного конкретного случая уже некоторое время
существует, но оно, к сожалению, не вошло в perl-5.8.7.

В исходниках interchange есть hackaround: вместо getppid() может
использоваться syscall(64) -- это не портабельно, но по меньшей мере
работает на Linux.  Чтобы включить этот hackaround, в interchange.cfg,
насколько я понял, нужно добавить
Variable MV_GETPPID_BROKEN 1

Других противопоказаний для threaded perl я не вижу.

[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]

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

end of thread, other threads:[~2005-06-04  1:02 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2005-06-02 17:42         ` [sisyphus] Re: Fwd: non-threaded perl (was: Зависимости пакетов и apt-get) Alexey Tourbin
2005-06-04  1:02             ` Alexey Tourbin

ALT Linux Sisyphus discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/sisyphus/0 sisyphus/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 sisyphus sisyphus/ http://lore.altlinux.org/sisyphus \
		sisyphus@altlinux.ru sisyphus@altlinux.org sisyphus@lists.altlinux.org sisyphus@lists.altlinux.ru sisyphus@lists.altlinux.com sisyphus@linuxteam.iplabs.ru sisyphus@list.linux-os.ru
	public-inbox-index sisyphus

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.sisyphus


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git