delorie.com/archives/browse.cgi   search  
Mail Archives: djgpp/2015/06/04/07:55:25

X-Authentication-Warning: delorie.com: mail set sender to djgpp-bounces using -f
X-Recipient: djgpp AT delorie DOT com
Message-ID: <55703CF2.5030900@gmx.de>
Date: Thu, 04 Jun 2015 13:56:34 +0200
From: "Juan Manuel Guerrero (juan DOT guerrero AT gmx DOT de)" <djgpp AT delorie DOT com>
User-Agent: Mozilla/5.0 (X11; U; Linux x86_64; de; rv:1.9.2.13) Gecko/20101206 SUSE/3.1.7 Thunderbird/3.1.7
MIME-Version: 1.0
To: bug-binutils AT gnu DOT org
CC: djgpp AT delorie DOT com
Subject: DJGPP port of binutils broken due to 64 bit cygwin fix.
X-Provags-ID: V03:K0:EMZWi65SOffMWmR6f0w6stDsqEBAw/4sJ5SdM9H38jag1k78cbC
DwBCRg08BjZY//ZhcgGMnlev+te6MprvrKFMLDf7QRYwazJJtx1SPN/77TMyW5nUy8et3yB
ltjQPx5OhLLjnjFfPxDFWT1IHPRU8tk0St9nnxt7Nu6GAfeNlhojfPGxGf24qPG9uo4DZa9
tAKVNXrQFJKR6uX+5Ss9A==
X-UI-Out-Filterresults: notjunk:1;V01:K0:22CLlC23tes=:Q3TNnVUgXbik8eHO3l2faE
/+IzGNjNuiifYNeqAQZDrPBwF4tRidJQN11hRXxOyRfMR4Igw6I/NcMyoh4TXAg05ueBPmNOV
In7UDSmJ+w06YihZJqwK7KQhDlS7Vr1KSXCwfcO4tyyZUbBZAJEl3VnZXmZ4vVuhKc0KgcVWK
44ju6PZvfKnw1/Bbktmv/gU+SMoPvrFmMrbiGFKWkaas2scWSX8MNfl3Noz5lcl4CeF9CuefN
0bcZPWCmtBymvy+05PZ2bz0xmX1SaG5P4GBRLDGWTg6B3WC4wGuGLVfEFL/SOL19BethPNC2C
umNC7MkQQNE10sGZij4KPNleBu2sK1SIJRqoE2YChaQvB5P5uMpB8NUHtbkBuOefysFvOw2+6
5LmeOFEgi9ZIxPqApw63fB2dvZgu/iTQnaBk/maXKzHt/BYE9PmdZRYri0w+EKGOc6a0kSYw2
k7rl452gWxkzFSNYgAb5VNpxOQH/eNs37ujhd9SmbinFzZUm70fAH8jgeUlmco0887a5Q9g42
oYBFIhmRs1qBL34xxLg20C5PL/Z+b8v63Y+6XE5a+K6QUtz9d6vnJ/XczbJCWluRU1b0LZqO4
X4ofDJC7X9axm5pwCwedByink6cICe9kjOStde6c6ox7olV1Sd7FmROf0zX9pGFLNoeW/pjbD
feqdSCDiOYghBeLMoRrDL1sg3VekMZURCCdvAbLHaWgRRvhAhqFLeCh9lvB2nsPjR6lU=
Reply-To: djgpp AT delorie DOT com

It turns out that the DJGPP (aka go32) port of binutils has been broken since
binutils 2.25 has been released.  The DJGPP port of binutils 2.24 and previous
versions works flawlessly.  Please note that there is nothing particular about
this port.  It is simply an absolute generic 32-bit coff system that uses DWARF2.

The breakage can be demonstrated by compiling a simple hello-world program with
the flags -g2 -O0.  If one tries to step through the code using the DJGPP port
of gdb then the following output will be displayed:


-----------------------  start of gdb output  -------------------------------

C:\tmp\5>gdb a.exe
GNU gdb (GDB) 7.7.1
Copyright (C) 2014 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
and "show warranty" for details.
This GDB was configured as "--host=i786-pc-msdosdjgpp --target=djgpp".
Type "show configuration" for configuration details.
For bug reporting instructions, please see:
<http://www.gnu.org/software/gdb/bugs/>.
Find the GDB manual and other documentation resources online at:
<http://www.gnu.org/software/gdb/documentation/>.
For help, type "help".
Type "apropos word" to search for commands related to "word"...
Reading symbols from a.exe...done.
(gdb) b main
Breakpoint 1 at 0x1f6a
(gdb) r
Starting program: c:/tmp/5/a.exe

Breakpoint 1, 0x00001f6a in main ()
(gdb) s
Single stepping until exit from function main,
which has no line number information.
hello world
0x00004504 in __crt1_startup ()
(gdb)

-----------------------  end of gdb output  -------------------------------




If one uses objdump to inspect the binary, using --dwarf, an output like this
will be produced:



-----------------------  start of objdump output  -------------------------------


a.exe:     file format coff-go32-exe

Contents of the .debug_aranges section:

C:\DJGPP-2.04\BIN/objdump.exe: Warning: Bogus end-of-siblings marker detected at offset b1 in .debug_info section
C:\DJGPP-2.04\BIN/objdump.exe: Warning: Bogus end-of-siblings marker detected at offset b2 in .debug_info section
C:\DJGPP-2.04\BIN/objdump.exe: Warning: DIE at offset b3 refers to abbreviation number 3986 which does not exist
   Length:                   28
   Version:                  2
   Offset into .debug_info:  0x0
   Pointer Size:             4
   Segment Size:             0
[snip, truncated by me]

Contents of the .debug_info section:

   Compilation Unit @ offset 0x0:
    Length:        0x46 (32-bit)
    Version:       2
    Abbrev Offset: 0x0
    Pointer Size:  4
  <0><b>: Abbrev Number: 1 (DW_TAG_compile_unit)
     <c>   DW_AT_stmt_list   : 0x0
     <10>   DW_AT_low_pc      : 0x1a10
     <14>   DW_AT_high_pc     : 0x1f27
     <18>   DW_AT_name        : crt0.S
     <1f>   DW_AT_comp_dir    : c:/djgpp-O0-g2/src/libc/crt0
     <3c>   DW_AT_producer    : GNU AS 2.25
     <48>   DW_AT_language    : 32769	(MIPS assembler)
   Compilation Unit @ offset 0x4a:
    Length:        0x19f (32-bit)
    Version:       2
    Abbrev Offset: 0x0
    Pointer Size:  4
  <0><55>: Abbrev Number: 1 (DW_TAG_compile_unit)
     <56>   DW_AT_stmt_list   : 0x20554e47
     <5a>   DW_AT_low_pc      : 0x2e342043
     <5e>   DW_AT_high_pc     : 0x20322e39
     <62>   DW_AT_name        : -fpreprocessed -mtune=pentium -march=pentium -g3 -gdwarf-2 -O0
     <a1>   DW_AT_comp_dir    : a.c
     <a6>   DW_AT_producer    : c:/tmp/5
     <af>   DW_AT_language    : 7984	(Unknown: 1f30)
  <0><b1>: Abbrev Number: 0
C:\DJGPP-2.04\BIN/objdump.exe: Warning: Bogus end-of-siblings marker detected at offset b1 in .debug_info section
C:\DJGPP-2.04\BIN/objdump.exe: Warning: Further warnings about bogus end-of-sibling markers suppressed
  <-1><b2>: Abbrev Number: 0
  <-2><b3>: Abbrev Number: 3986
C:\DJGPP-2.04\BIN/objdump.exe: Warning: DIE at offset b3 refers to abbreviation number 3986 which does not exist
Contents of the .debug_abbrev section:
[snip, truncated by me]


   Offset:                      0x6e0a
   Length:                      78
   DWARF Version:               2
   Prologue Length:             58
   Minimum Instruction Length:  1
   Initial value of 'is_stmt':  1
   Line Base:                   -5
   Line Range:                  14
   Opcode Base:                 13

[snip, truncated by me]

C:\DJGPP-2.04\BIN/objdump.exe: Warning: Unable to load/parse the .debug_info section, so cannot interpret the .debug_loc section.
C:\DJGPP-2.04\BIN/objdump.exe: Warning: Unable to load/parse the .debug_info section, so cannot interpret the .debug_ranges section.
Contents of the .debug_macro section:
[snip, truncated by me]

-----------------------  end of objdump output  -------------------------------



Please note that I have intentionally truncated a lot of the output produced by
objdump.  But I think that everyone can see that the debug info stored in the
file has been corrupted.


An inspection of the repository of binutils, specially a comparision between
the binutil-2_25-branch/master and the binutil-2_24-branch reveals that the
function _bfd_coff_generic_relocate_section in bfd/cofflink.c has been modified
by the following patch (55bfc9ac025c1c9cd1ad5422829b3dc70f357a79):

Autor: Nick Clifton <nickc AT redhat DOT com>  2014-03-26 17:16:20
Eintragender: Nick Clifton <nickc AT redhat DOT com>  2014-03-26 17:16:20
Eltern: 318d3177f7d67dac94baa07aab04192fc7bcba49 (Remove VAR_DOMAIN/STRUCT_DOMAIN ambiguity from ada-tasks.c.)
Kind:  b3fe4307a625457c6953fce27bbbfc4c90e38e9d (Add support for %hi8, %hi16 and %lo16 being used when relocation are necessary.)
Zweig: binutils-2_25-branch, master, remotes/origin/binutils-2_25-branch and many more (44)
Folgt auf: binu_ss_19990502, readline_4_0
Vorgänger von: binutils-2_25, gdb-7.8-release, gdb-7.9.0-release, hjl/linux/release/2.24.51.0.4

     This fixes a problem for 64-bit Cygwin, where building some packages can
     produce spurious errors about truncated relocations.  The relocations are
     only truncated because they are being made against sections which are going
     to be discarded so that base address is zero instead of the expected 64-bit
     base value.

     	* cofflink.c (_bfd_coff_generic_relocate_section): Skip
     	relocations in discarded sections.





@@ -3059,6 +3059,11 @@ _bfd_coff_generic_relocate_section (bfd *output_bfd,
  	  else
  	    {
  	      sec = sections[symndx];
+
+	      /* If the output section has been discarded then ignore this reloc.  */
+	      if (sec->output_section->vma == 0)
+		continue;
+
                val = (sec->output_section->vma
  		     + sec->output_offset
  		     + sym->n_value);




Because the DJGPP port is an absolute _generic_ 32-bit coff system I suspect
that the patch above has probably brocken almost every coff 32-bit systems
except for pe-coff may be.


I have solved the issue for myself by this change:


diff --git a/bfd/cofflink.c b/bfd/cofflink.c
index ef9e362..162d832 100644
--- a/bfd/cofflink.c
+++ b/bfd/cofflink.c
@@ -2979,9 +2979,13 @@ _bfd_coff_generic_relocate_section (bfd *output_bfd,
  	    {
  	      sec = sections[symndx];

+
+	      /* Only if not a 32-bit system.  */
+#ifndef __DJGPP__
  	      /* If the output section has been discarded then ignore this reloc.  */
  	      if (sec->output_section->vma == 0)
  		continue;
+#endif

                val = (sec->output_section->vma
  		     + sec->output_offset


Of course this should not be fixed in this way.  Unfortunately my bfd skills
are to limited to disign a solution that would identify that coff version that
requires the ignoring of the discarded relocations and those versions that do
not.  If someone creates a solution for this issue and need assitance to test
it, please contact me.


Regards,
Juan M. Guerrero

- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019