ALT Linux Team development discussions
 help / color / mirror / Atom feed
From: Alexey Tourbin <at@altlinux.ru>
To: ALT Devel discussion list <devel@lists.altlinux.org>
Subject: [devel] rpmelfsymv
Date: Wed, 9 Aug 2006 02:03:42 +0400
Message-ID: <20060808220342.GD16715@localhost.localdomain> (raw)
In-Reply-To: <20060808183618.GC16715@localhost.localdomain>

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

On Tue, Aug 08, 2006 at 10:36:18PM +0400, Alexey Tourbin wrote:
> On Tue, Aug 08, 2006 at 04:30:44PM +0400, Dmitry V. Levin wrote:
> > На старом libgcc не запустится:
> > $ rpmquery -pR FlightGear-0.9.10-alt1.i586.rpm |fgrep libgcc
> > libgcc_s.so.1(GCC_3.0)  
> > libgcc_s.so.1(GCC_4.0.0) 
> > 
> > На конфренеции Алексею пеняли, что его робот не учитывает versioning.

Понимаешь в чем дело.  Есть несколько проблем, которые всё усложняют.
Вот первая из них:

> Что нужно использовать вместо nm -D, чтобы получить отношение
> <типа символа> <символ> <версия символа> ?

Почему-то мне хочется сохранить однобуквенное обозначение типа символа,
как в nm -D.  При этом нужно добавить в таблицу ещё одно поле, в
котором будет версия символа (или прочерк, если версии нет).

Как это можно сделать?  Сначала запустить nm -D, а потом ещё раз
запустить readelf или же objdump.  Я остановился на objdump (его удобнее
использовать с xargs).  Вот что пока получается получается:

--- rpmelfsym	2006-05-27 11:15:29 +0000
+++ rpmelfsymv	2006-08-08 21:54:15 +0000
@@ -1,17 +1,22 @@
 #!/bin/sh -ef
 export LC_ALL=C
 
-rpmelfsym()
+rpmelfsymv()
 {
 	rpmfile "$1" >files
 	awk -F'\t' '$NF~/ELF.*(dynamic|shared)/{printf"./%s\0",$1}' files >elfs0
 	[ -s elfs0 ] || return 0
 	rpmpeek "$1" xargs -r0 nm -Do <elfs0 >nm.out
-	awk '{OFS="\t";sub("^./","",$1);sub(":[0-9a-fA-F]*$","",$1);print}' nm.out
+	awk '{OFS="\t";sub("^./","",$1);sub(":[0-9a-fA-F]*$","",$1);print}' nm.out >elfsym
+	rpmpeek "$1" xargs -r0 objdump -Tw  <elfs0 >objdump.out
+	awk --lint '{OFS="\t"}
+		sub(/:[[:space:]]+file format.+/,""){sub("^./","");f=$0;next}
+		sub(/.+\t/,"")&&NF>2&&$(NF-1)!="Base"{print f,$NF,$(NF-1)}' objdump.out >elfsymv
+	head elfsym elfsymv
 }
 
 . cmdcache ""
-. rpmargs -c "cmdcache rpmelfsym" "$@"
+. rpmargs -c "rpmelfsymv" "$@"
 
 : <<'__EOF__'
 
И вот что выдает:

$ ./rpmelfsymv ~sisyphus/files/i586/RPMS/perl-base-5.8.8-alt1.i586.rpm  
==> elfsym <==
/usr/bin/perl5.8.8      U       PL_do_undump
/usr/bin/perl5.8.8      U       PL_op_mutex
/usr/bin/perl5.8.8      U       PL_sigfpe_saved
/usr/bin/perl5.8.8      U       PL_use_safe_putenv
/usr/bin/perl5.8.8      U       Perl_atfork_lock
/usr/bin/perl5.8.8      U       Perl_atfork_unlock
/usr/bin/perl5.8.8      U       Perl_croak_nocontext
/usr/bin/perl5.8.8      U       Perl_newXS
/usr/bin/perl5.8.8      R       _IO_stdin_used
/usr/bin/perl5.8.8      w       _Jv_RegisterClasses

==> elfsymv <==
/usr/bin/perl5.8.8      signal  GLIBC_2.0
/usr/bin/perl5.8.8      pthread_mutex_destroy   GLIBC_2.0
/usr/bin/perl5.8.8      __register_atfork       GLIBC_2.3.2
/usr/bin/perl5.8.8      boot_DynaLoader DynaLoader
/usr/bin/perl5.8.8      __libc_start_main       GLIBC_2.0
/usr/bin/perl5.8.8      memcpy  GLIBC_2.0
/usr/bin/perl5.8.8      exit    GLIBC_2.0
/usr/lib/libperl.so.5.8.8       readlink        GLIBC_2.0
/usr/lib/libperl.so.5.8.8       atol    GLIBC_2.0
/usr/lib/libperl.so.5.8.8       nl_langinfo     GLIBC_2.0
$

Значит есть две таблицы: в одной есть тип, но нет версии; а в другой
есть версия, но нет типа.  Эти таблицы нужно соединять по двум полям:
по имени файла и имени символа, join(1) такое не умеет.  Допустим, есть
два способа обойти это ограничение join, не суть важно.

Внимание, вопрос: могут ли два одинаковых символа с разными версиями
иметь разные типы?  Т.е. symbol@LIB_1.0 -- T (функция), symbol@LIB_1.1 --
D (переменная).  Как тогда правильно соединить тип и версию?  И какой тип
на самом деле показывает nm -D?

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

  reply	other threads:[~2006-08-08 22:03 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2006-08-08 11:50 ` [devel] [Sisyphus-cybertalk] I: Sisyphus-20060808 abi_drifts: +23 -18 (5193) Michael Shigorin
2006-08-08 12:30   ` Dmitry V. Levin
2006-08-08 18:36     ` Alexey Tourbin
2006-08-08 22:03       ` Alexey Tourbin [this message]
2006-08-08 23:16         ` [devel] rpmelfsymv Dmitry V. Levin
2006-08-13 16:59           ` Alexey Tourbin
2006-08-21 15:19             ` Alexey Tourbin
2006-08-08 19:07     ` [devel] [Sisyphus-cybertalk] I: Sisyphus-20060808 abi_drifts: +23 -18 (5193) Michael Shigorin

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=20060808220342.GD16715@localhost.localdomain \
    --to=at@altlinux.ru \
    --cc=devel@lists.altlinux.org \
    /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