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 --]
next prev parent 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