ALT Linux Team development discussions
 help / color / mirror / Atom feed
* Re: [devel] xplc-0.3.12-alt1.1: rebuild failed [6]
  @ 2006-04-16 21:45 ` Alexey Tourbin
  2006-04-16 21:50   ` Dmitry V. Levin
  0 siblings, 1 reply; 6+ messages in thread
From: Alexey Tourbin @ 2006-04-16 21:45 UTC (permalink / raw)
  To: devel

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

On Mon, Apr 17, 2006 at 12:24:57AM +0400, QA Team Robot wrote:
> i586-alt-linux-g++ -pipe -Wall -O2 -march=i586 -mtune=pentium4 -pipe -Wall -O2 -march=i586 -mtune=pentium4 -O2 -DNDEBUG -Wall -Woverloaded-virtual -fno-rtti -fno-exceptions -fpic -DUNSTABLE -pipe -Iinclude  -ldl  -shared -Wl,-hlibxplc-0.3.so -Wl,-z,defs,--version-script=config/exports.map xplc/category.o xplc/catiter.o xplc/catmgr.o xplc/loader.o xplc/moduleloader.o xplc/modulemgr.o xplc/monikers.o xplc/new.o xplc/servmgr.o xplc/statichandler.o libxplc-cxx.so -o libxplc.so
> xplc/loader.o: In function `loaderOpen(char const*, void**)':loader.cpp:(.text+0x16): undefined reference to `dlerror'
> :loader.cpp:(.text+0x29): undefined reference to `dlopen'
> :loader.cpp:(.text+0x40): undefined reference to `dlerror'
> xplc/loader.o: In function `loaderSymbol(void*, char const*, void**)':loader.cpp:(.text+0x63): undefined reference to `dlerror'
> :loader.cpp:(.text+0x75): undefined reference to `dlsym'
> :loader.cpp:(.text+0x7f): undefined reference to `dlerror'
> xplc/loader.o: In function `loaderClose(void*&)':loader.cpp:(.text+0xa6): undefined reference to `dlclose'
> collect2: ld returned 1 exit status
> make: *** [libxplc.so] Error 1
> make: Leaving directory `/usr/src/RPM/BUILD/xplc-0.3.12'

Глюк компилятора.  Происходит примерно вот что (в упрощенном виде).

$ g++ -ldl -shared -Wl,-hlibxplc-0.3.so -Wl,--version-script=config/exports.map xplc/category.o xplc/catiter.o xplc/catmgr.o xplc/loader.o xplc/moduleloader.o xplc/modulemgr.o xplc/monikers.o xplc/new.o xplc/servmgr.o xplc/statichandler.o libxplc-cxx.so -o libxplc.so -Wl,-z,defs
xplc/loader.o: In function `loaderOpen(char const*, void**)':loader.cpp:(.text+0x1a): undefined reference to `dlerror'
:loader.cpp:(.text+0x2d): undefined reference to `dlopen'
:loader.cpp:(.text+0x45): undefined reference to `dlerror'
xplc/loader.o: In function `loaderSymbol(void*, char const*, void**)':loader.cpp:(.text+0x73): undefined reference to `dlerror'
:loader.cpp:(.text+0x85): undefined reference to `dlsym'
:loader.cpp:(.text+0x8f): undefined reference to `dlerror'
xplc/loader.o: In function `loaderClose(void*&)':loader.cpp:(.text+0xc0): undefined reference to `dlclose'
collect2: ld returned 1 exit status
$

То есть я даю ему -ldl, но он в упор не видит dlopen.

Теперь я переставляю -ldl с первого места на последнее:

$ g++ -shared -Wl,-hlibxplc-0.3.so -Wl,--version-script=config/exports.map xplc/category.o xplc/catiter.o xplc/catmgr.o xplc/loader.o xplc/moduleloader.o xplc/modulemgr.o xplc/monikers.o xplc/new.o xplc/servmgr.o xplc/statichandler.o libxplc-cxx.so -o libxplc.so -Wl,-z,defs -ldl
$

Получилось!
Документирован ли порядок аргументов у gcc?

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

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

* Re: [devel] xplc-0.3.12-alt1.1: rebuild failed [6]
  2006-04-16 21:45 ` [devel] xplc-0.3.12-alt1.1: rebuild failed [6] Alexey Tourbin
@ 2006-04-16 21:50   ` Dmitry V. Levin
  2006-04-16 22:37     ` Alexey Tourbin
  0 siblings, 1 reply; 6+ messages in thread
From: Dmitry V. Levin @ 2006-04-16 21:50 UTC (permalink / raw)
  To: ALT Devel discussion list

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

On Mon, Apr 17, 2006 at 01:45:32AM +0400, Alexey Tourbin wrote:
> Глюк компилятора.  Происходит примерно вот что (в упрощенном виде).
> 
> $ g++ -ldl -shared -Wl,-hlibxplc-0.3.so -Wl,--version-script=config/exports.map xplc/category.o xplc/catiter.o xplc/catmgr.o xplc/loader.o xplc/moduleloader.o xplc/modulemgr.o xplc/monikers.o xplc/new.o xplc/servmgr.o xplc/statichandler.o libxplc-cxx.so -o libxplc.so -Wl,-z,defs
> xplc/loader.o: In function `loaderOpen(char const*, void**)':loader.cpp:(.text+0x1a): undefined reference to `dlerror'
> :loader.cpp:(.text+0x2d): undefined reference to `dlopen'
> :loader.cpp:(.text+0x45): undefined reference to `dlerror'
> xplc/loader.o: In function `loaderSymbol(void*, char const*, void**)':loader.cpp:(.text+0x73): undefined reference to `dlerror'
> :loader.cpp:(.text+0x85): undefined reference to `dlsym'
> :loader.cpp:(.text+0x8f): undefined reference to `dlerror'
> xplc/loader.o: In function `loaderClose(void*&)':loader.cpp:(.text+0xc0): undefined reference to `dlclose'
> collect2: ld returned 1 exit status
> $
> 
> То есть я даю ему -ldl, но он в упор не видит dlopen.
> 
> Теперь я переставляю -ldl с первого места на последнее:
> 
> $ g++ -shared -Wl,-hlibxplc-0.3.so -Wl,--version-script=config/exports.map xplc/category.o xplc/catiter.o xplc/catmgr.o xplc/loader.o xplc/moduleloader.o xplc/modulemgr.o xplc/monikers.o xplc/new.o xplc/servmgr.o xplc/statichandler.o libxplc-cxx.so -o libxplc.so -Wl,-z,defs -ldl
> $
> 
> Получилось!

Лёш, это не глюк, это --as-needed, видимо, ты пропустил эту историю, см.
напр. http://wiki.sisyphus.ru/devel/UpStream/AsNeeded


-- 
ldv

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

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

* Re: [devel] xplc-0.3.12-alt1.1: rebuild failed [6]
  2006-04-16 21:50   ` Dmitry V. Levin
@ 2006-04-16 22:37     ` Alexey Tourbin
  2006-04-16 22:47       ` Dmitry V. Levin
  0 siblings, 1 reply; 6+ messages in thread
From: Alexey Tourbin @ 2006-04-16 22:37 UTC (permalink / raw)
  To: ALT Devel discussion list

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

On Mon, Apr 17, 2006 at 01:50:27AM +0400, Dmitry V. Levin wrote:
> > Теперь я переставляю -ldl с первого места на последнее:
> > 
> > $ g++ -shared -Wl,-hlibxplc-0.3.so -Wl,--version-script=config/exports.map xplc/category.o xplc/catiter.o xplc/catmgr.o xplc/loader.o xplc/moduleloader.o xplc/modulemgr.o xplc/monikers.o xplc/new.o xplc/servmgr.o xplc/statichandler.o libxplc-cxx.so -o libxplc.so -Wl,-z,defs -ldl
> > $
> > 
> > Получилось!
> 
> Лёш, это не глюк, это --as-needed, видимо, ты пропустил эту историю, см.
> напр. http://wiki.sisyphus.ru/devel/UpStream/AsNeeded

Кажется я догадываюсь, как это реализовано: компилятор (линкер в данном
случае) сканирует аргументы командной строки слева направо.  Он видит
-ldl и проверяет, использует ли создаваемый ELF shared object какие-либо
символы из -ldl.  Поскольку создаваемый ELF в данном случае вообще
пустой, компилятор выбрасывает -ldl и идёт дальше.  Потом ему попадаются
объектные файлы с dlopen(), но -ldl уже проехали.  В конце
активизируется -Wl,-z,defs и отваливает.

Если считать это такое поведение компилятора консистентным (особенно с
точки зрения "Rule of Least Surprise"), тогда я наверное великий
Корнхолио.  Поэтому я и спрашиваю: документирован порядок обработки
аргументов или нет.

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

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

* Re: [devel] xplc-0.3.12-alt1.1: rebuild failed [6]
  2006-04-16 22:37     ` Alexey Tourbin
@ 2006-04-16 22:47       ` Dmitry V. Levin
  2006-04-17  1:00         ` Alexey Tourbin
  0 siblings, 1 reply; 6+ messages in thread
From: Dmitry V. Levin @ 2006-04-16 22:47 UTC (permalink / raw)
  To: ALT Devel discussion list

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

On Mon, Apr 17, 2006 at 02:37:50AM +0400, Alexey Tourbin wrote:
> On Mon, Apr 17, 2006 at 01:50:27AM +0400, Dmitry V. Levin wrote:
> > > Теперь я переставляю -ldl с первого места на последнее:
> > > 
> > > $ g++ -shared -Wl,-hlibxplc-0.3.so -Wl,--version-script=config/exports.map xplc/category.o xplc/catiter.o xplc/catmgr.o xplc/loader.o xplc/moduleloader.o xplc/modulemgr.o xplc/monikers.o xplc/new.o xplc/servmgr.o xplc/statichandler.o libxplc-cxx.so -o libxplc.so -Wl,-z,defs -ldl
> > > $
> > > 
> > > Получилось!
> > 
> > Лёш, это не глюк, это --as-needed, видимо, ты пропустил эту историю, см.
> > напр. http://wiki.sisyphus.ru/devel/UpStream/AsNeeded
> 
> Кажется я догадываюсь, как это реализовано: компилятор (линкер в данном
> случае) сканирует аргументы командной строки слева направо.  Он видит
> -ldl и проверяет, использует ли создаваемый ELF shared object какие-либо
> символы из -ldl.  Поскольку создаваемый ELF в данном случае вообще
> пустой, компилятор выбрасывает -ldl и идёт дальше.  Потом ему попадаются
> объектные файлы с dlopen(), но -ldl уже проехали.  В конце
> активизируется -Wl,-z,defs и отваливает.

Именно так оно и происходит, это уже здесь обсуждалось, см.
http://lists.altlinux.org/pipermail/devel/2006-March/029704.html
и в целом архив этого списка за прошлый месяц с темой --as-needed.

> Если считать это такое поведение компилятора консистентным (особенно с
> точки зрения "Rule of Least Surprise"), тогда я наверное великий
> Корнхолио.  Поэтому я и спрашиваю: документирован порядок обработки
> аргументов или нет.

Наверняка документирован.


-- 
ldv

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

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

* Re: [devel] xplc-0.3.12-alt1.1: rebuild failed [6]
  2006-04-16 22:47       ` Dmitry V. Levin
@ 2006-04-17  1:00         ` Alexey Tourbin
  2006-04-17 11:27           ` [devel] gcc, порядок аргументов и --as-needed (was: xplc-0.3.12-alt1.1: rebuild failed [6]) Michael Shigorin
  0 siblings, 1 reply; 6+ messages in thread
From: Alexey Tourbin @ 2006-04-17  1:00 UTC (permalink / raw)
  To: ALT Devel discussion list

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

On Mon, Apr 17, 2006 at 02:47:27AM +0400, Dmitry V. Levin wrote:
> > Кажется я догадываюсь, как это реализовано: компилятор (линкер в данном
> > случае) сканирует аргументы командной строки слева направо.  Он видит
> > -ldl и проверяет, использует ли создаваемый ELF shared object какие-либо
> > символы из -ldl.  Поскольку создаваемый ELF в данном случае вообще
> > пустой, компилятор выбрасывает -ldl и идёт дальше.  Потом ему попадаются
> > объектные файлы с dlopen(), но -ldl уже проехали.  В конце
> > активизируется -Wl,-z,defs и отваливает.
> 
> Именно так оно и происходит, это уже здесь обсуждалось, см.
> http://lists.altlinux.org/pipermail/devel/2006-March/029704.html
> и в целом архив этого списка за прошлый месяц с темой --as-needed.

В два прохода надо делать: сначала *.o, потом *.so, и потом только
решать, какие из *.so оставлять.  Но есть ещё *.a.  Не понятно тогда,
вклинивать ли *.a перед *.so или после *.so.  На это ещё -static может
влиять.  Короче точную формулировку в соответствии c "Rule of Least
Surprise" с ходу дать затруднительно.

Лучше бы порядок аргументов и соответствующая семантика были
исчерпывающим образом документированы.  А то получается кур смешить:
--as-needed должен отсекать только ненужные библиотеки, а на деле
может отсекать и нужные.

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

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

* [devel] gcc, порядок аргументов и --as-needed (was: xplc-0.3.12-alt1.1: rebuild failed [6])
  2006-04-17  1:00         ` Alexey Tourbin
@ 2006-04-17 11:27           ` Michael Shigorin
  0 siblings, 0 replies; 6+ messages in thread
From: Michael Shigorin @ 2006-04-17 11:27 UTC (permalink / raw)
  To: ALT Devel discussion list

On Mon, Apr 17, 2006 at 05:00:02AM +0400, Alexey Tourbin wrote:
> Короче точную формулировку в соответствии c "Rule of Least
> Surprise" с ходу дать затруднительно.

Но ощущение нарушения принципа IBM витает в воздухе...

Как думаешь -- это исправимо вообще?

-- 
 ---- WBR, Michael Shigorin <mike@altlinux.ru>
  ------ Linux.Kiev http://www.linux.kiev.ua/


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

end of thread, other threads:[~2006-04-17 11:27 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2006-04-16 21:45 ` [devel] xplc-0.3.12-alt1.1: rebuild failed [6] Alexey Tourbin
2006-04-16 21:50   ` Dmitry V. Levin
2006-04-16 22:37     ` Alexey Tourbin
2006-04-16 22:47       ` Dmitry V. Levin
2006-04-17  1:00         ` Alexey Tourbin
2006-04-17 11:27           ` [devel] gcc, порядок аргументов и --as-needed (was: xplc-0.3.12-alt1.1: rebuild failed [6]) Michael Shigorin

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