ALT Linux Team development discussions
 help / color / mirror / Atom feed
From: Alexey Tourbin <at@altlinux.ru>
To: ALT Devel discussion list <devel@altlinux.ru>
Subject: [devel] Re: q: _perl_vendor_check_dso problems
Date: Mon, 26 Sep 2005 17:57:08 +0400
Message-ID: <20050926135708.GB3650@solemn.turbinal.org> (raw)
In-Reply-To: <4337F64B.20505@gorodmasterov.com>

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

On Mon, Sep 26, 2005 at 05:23:23PM +0400, Vladimir Lettiev wrote:
> Нет, безрезультатно.
> Похоже все указанные функции проглядываются в *.h файлах, которые 
> принадлежат пакету apache-mod_perl.

Эти функции *должны* быть в какой-то *.so библиотеке.  Если эта
библиотека публичная, то есть предназначена для непосредственной
линковки, то лучше всего с ней слинковаться.

> Это где-то в этом районе:
> /usr/lib/perl5/vendor_perl/i386-linux/auto/Apache/include/

Если же это библиотека типа loadable module, то есть не предназначена
для непосредственной линковки, то можно "подстроить" проверку.  Пример
из perl-Gtk2-GladeXML.spec:

EXTRA_BLIBS=`ls %perl_vendor_autolib/{Glib/Glib,Gtk2/Gtk2}.so`
%perl_vendor_build

При загрузке Glib.so и Gtk2.so используется RTLD_GLOBAL, это такой
хитрый/окольный ELF механизм для глобального импорта символов из
объекта, который загружается с помощью dlopen().

Поиск по символам показывает, что функции ap_table_do и др. находятся
в /usr/lib/apache/libhttpd.so:

apache  /usr/lib/apache/libhttpd.so     T       ap_table_do
apache-mod_perl /usr/sbin/httpd-perl    T       ap_table_do

Я вообще не знаю, как всё это работает, то есть как в процессе
динамической линковки подцепляется libhttpd.so.  Если есть уверенность,
что оно действительно работает, то проще всего модифицировать проверку:

EXTRA_BLIBS=`ls %_libdir/apache/libhttpd.so`
%perl_vendor_build

Но у libhttpd.so в свою очередь тоже есть undefined symbols:

$ ldd -r /usr/lib/apache/libhttpd.so 2>&1 |head
        libc.so.6 => /lib/i686/libc.so.6 (0x40074000)
        /lib/ld-linux.so.2 => /lib/ld-linux.so.2 (0x80000000)
undefined symbol: mm_core_delete        (/usr/lib/apache/libhttpd.so)
undefined symbol: dlerror       (/usr/lib/apache/libhttpd.so)
undefined symbol: MM_create     (/usr/lib/apache/libhttpd.so)
undefined symbol: deflate       (/usr/lib/apache/libhttpd.so)
undefined symbol: mm_maxsize    (/usr/lib/apache/libhttpd.so)
undefined symbol: mm_core_align2page    (/usr/lib/apache/libhttpd.so)
undefined symbol: MM_destroy    (/usr/lib/apache/libhttpd.so)
undefined symbol: mm_create     (/usr/lib/apache/libhttpd.so)
$

Всё это как-то криво и работает "на честном слове и на одном крыле".
Символы MM_create и др. есть и libmm:

libmm   /usr/lib/libmm.so.1.3.0 T       MM_create

Если добавить в EXTRA_BLIBS libmm, то проверка опять не проходит:

$ gcc ~/ldtest.c /usr/lib/apache/libhttpd.so /usr/lib/libmm.so
/usr/lib/apache/libhttpd.so: undefined reference to `dlerror'
/usr/lib/apache/libhttpd.so: undefined reference to `deflate'
/usr/lib/apache/libhttpd.so: undefined reference to `dlclose'
/usr/lib/apache/libhttpd.so: undefined reference to `crc32'
/usr/lib/apache/libhttpd.so: undefined reference to `dlopen'
/usr/lib/apache/libhttpd.so: undefined reference to `deflateInit2_'
/usr/lib/apache/libhttpd.so: undefined reference to `crypt'
/usr/lib/apache/libhttpd.so: undefined reference to `dlsym'
/usr/lib/apache/libhttpd.so: undefined reference to `deflateEnd'

Опыты показывают, что проверка в конечном счете будет работать так:

$ gcc ~/ldtest.c /usr/lib/apache/libhttpd.so -lmm -ldl -lcrypt -lz

То есть придётся написать 

EXTRA_BLIBS='/usr/lib/apache/libhttpd.so -lmm -ldl -lcrypt -lz'
%perl_vendor_build

Излишне говорить, что всё это сводит на нет смысл проверки.

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

  reply	other threads:[~2005-09-26 13:57 UTC|newest]

Thread overview: 15+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2005-09-26 12:52 [devel] " Vladimir Lettiev
2005-09-26 13:01 ` [devel] " Alexey Tourbin
2005-09-26 13:23   ` Vladimir Lettiev
2005-09-26 13:57     ` Alexey Tourbin [this message]
2005-09-26 14:09       ` Alexey I.Froloff
2005-09-26 14:13       ` Dmitry V. Levin
2005-09-26 14:24         ` Michael Shigorin
2005-09-26 14:25         ` Alexey I.Froloff
2005-09-26 14:49           ` Alexey Tourbin
2005-09-26 21:39           ` Igor Zubkov
2005-09-26 14:41         ` Alexey Tourbin
2005-09-26 15:26           ` [devel] verify-elf Dmitry V. Levin
2005-09-26 16:05             ` [devel] verify-elf Alexey Tourbin
2005-09-26 16:57               ` Dmitry V. Levin
2005-09-26 17:56       ` [devel] Re: q: _perl_vendor_check_dso problems Konstantin A.Lepikhov

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=20050926135708.GB3650@solemn.turbinal.org \
    --to=at@altlinux.ru \
    --cc=devel@altlinux.ru \
    /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