2010/9/28 Jakub Jelinek <ja...@redhat.com>: > On Mon, Sep 27, 2010 at 05:29:19PM -0700, Richard Henderson wrote: >> The 64-bit PEI format has a SECREL32 relocation type. It >> does not, however, have a SECREL64 relocation type. Which >> means that for >> >> > #define DWARF_REF_SIZE \ >> > (dwarf_version == 2 ? DWARF2_ADDR_SIZE : DWARF_OFFSET_SIZE) >> >> we don't really have something to use for for dwarf2. >> >> I could fake it with >> >> .secrel32 ref >> .long 0 > > This is something we already use for TLS on x86_64: > .byte 0xa # DW_AT_location > .byte 0xe # DW_OP_const8u > .long i...@dtpoff, 0 > At least for relocations that are always resolved to locations > within the same .debug_info section they will be always unsigned > and thus using .secrel 32 ref; .long 0 is IMHO just fine, and > implicit pointer currently will never reference anything outside of the > current executable's or shared library's CU.
So I suggest the following patch. I tested it for x86_64-w64-mingw32 and didn't got regressions. Also the eh/register1.C test produces correct abbreviations (tested by objdump -Wi). ChangeLog 2010-09-28 Kai Tietz * config/i386/cygming.h (ASM_OUTPUT_DWARF_OFFSET): Output addition zero for padding of secrel32 requested for 8 bytes. I will apply this today, if there aren't any objections. Regards, Kai -- | (\_/) This is Bunny. Copy and paste | (='.'=) Bunny into your signature to help | (")_(") him gain world domination
w64_secrel.diff
Description: Binary data