On Tue, Oct 22, 2002 at 10:45:52AM -0400, Andrew Gallatin wrote: > > Ruslan Ermilov writes: > > If you remove -fno-exceptions from gnu/usr.bin/groff/Makefile.inc and > > recompile libgroff and groff, it seems to work (I did not check it > > thoroughly). But I think this only has a side effect, because Groff > > does not seem to have any exception code (please correct me if I am > > wrong), and why the hell it should depend on -mcpu, if any? > > > > Interesting. I wonder of the lack of exceptions is what's confusing > ld? > Seems so.
With -fno-exceptions and last delta to groff/Makefile backed out: $ roff/groff/groff -V /usr/libexec/ld-elf.so.1: roff/groff/groff: too few PT_LOAD segments The same, but without -fno-exceptions: $ roff/groff/groff -V troff -Tps | grops I wonder if the follwing commit might be relevant to the -DNOSHARED issue with groff: : kan 2002/10/19 16:03:35 PDT : : Modified files: : libexec/rtld-elf rtld.c : Log: : Change the symbol lookup order to search RTLD_GLOBAL objects : before referencing object's DAG. This makes it possible for : C++ exceptions to work across shared libraries and brings : us closer to the search order used by Solaris/Linux. : : Reviewed by: jdp : Approved by: obrien : MFC after: 1 month : : Revision Changes Path : 1.68 +12 -12 src/libexec/rtld-elf/rtld.c > As to mpcu: On alphas, the compiler has more chance to make mistakes > if its compiled for CPUs < ev56 which do not support byte/word > instructions. In those cases, it needs to generate shifty/masky code > to pull 8 and 16 bit values out of 32-bit loads and stores. This has > a history of being more error prone. Eg, some complex ports work on > stable at high optimization levels with -mcpu=ev56 which don't work > without -mpcu. > > If we have to, we can always compile groff as -mcpu=ev56 because we > emulate these instructions in the kernel on older machines. That > would make groff run about like molases in January on older machines, > though, as each byte/word instruction would generate an illegal > instruction trap and that trap would be handled by the alpha trap > handler.. > Can't we make it the default in GCC, or in share/mk/bsd.cpu.mk? Cheers, -- Ruslan Ermilov Sysadmin and DBA, [EMAIL PROTECTED] Sunbay Software AG, [EMAIL PROTECTED] FreeBSD committer, +380.652.512.251 Simferopol, Ukraine http://www.FreeBSD.org The Power To Serve http://www.oracle.com Enabling The Information Age
msg45039/pgp00000.pgp
Description: PGP signature