[LLVMbugs] [Bug 15448] New: -fasynchronous-unwind-tables different result .c -> .so versus .c -> .s -> .so

bugzilla-daemon at llvm.org bugzilla-daemon at llvm.org
Tue Mar 5 07:07:35 PST 2013


http://llvm.org/bugs/show_bug.cgi?id=15448

            Bug ID: 15448
           Summary: -fasynchronous-unwind-tables different result .c ->
                    .so versus .c -> .s -> .so
           Product: clang
           Version: 3.2
          Hardware: PC
                OS: FreeBSD
            Status: NEW
          Severity: normal
          Priority: P
         Component: -New Bugs
          Assignee: unassignedclangbugs at nondot.org
          Reporter: tijl at coosemans.org
                CC: llvmbugs at cs.uiuc.edu
    Classification: Unclassified

Starting with the following C code test.c:

----
int func( void ) {
  return( 0 );
}
----

Create libtest-1.so:

clang -o libtest-1.so test.c -shared -fasynchronous-unwind-tables -fPIC

Create libtest-2.so:

clang -S test.c -fasynchronous-unwind-tables -fPIC
clang -o libtest-2.so test.s -shared

These two libraries are different. Moreover libtest-2.so contains text
relocations (DF_TEXTREL).

Running the same commands with gcc 4.7 results in two identical libraries.

When comparing the object files test-1.o and test-2.o there's a difference in
the .rel.eh_frame section:
clang -o test-1.o -c test.c -fasynchronous-unwind-tables -fPIC
clang -o test-2.o -c test.s

readelf -r test-1.o

Relocation section '.rel.eh_frame' at offset 0x2e0 contains 1 entries:
 Offset     Info    Type            Sym.Value  Sym. Name
00000020  00000202 R_386_PC32        00000000   .text

readelf -r test-2.o

Relocation section '.rel.eh_frame' at offset 0x364 contains 1 entries:
 Offset     Info    Type            Sym.Value  Sym. Name
00000020  00000201 R_386_32          00000000   .text

With gcc the type of the relocation is R_386_PC32 in both cases.

OS: FreeBSD 10.0 x86

-- 
You are receiving this mail because:
You are on the CC list for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-bugs/attachments/20130305/d56fd7d5/attachment.html>


More information about the llvm-bugs mailing list