summaryrefslogtreecommitdiff
path: root/source/d/binutils/patches/binutils-dwarf-5-dir0.patch
diff options
context:
space:
mode:
Diffstat (limited to 'source/d/binutils/patches/binutils-dwarf-5-dir0.patch')
-rw-r--r--source/d/binutils/patches/binutils-dwarf-5-dir0.patch201
1 files changed, 0 insertions, 201 deletions
diff --git a/source/d/binutils/patches/binutils-dwarf-5-dir0.patch b/source/d/binutils/patches/binutils-dwarf-5-dir0.patch
deleted file mode 100644
index 24233cce..00000000
--- a/source/d/binutils/patches/binutils-dwarf-5-dir0.patch
+++ /dev/null
@@ -1,201 +0,0 @@
-diff -rup binutils.orig/gas/dwarf2dbg.c binutils-2.37/gas/dwarf2dbg.c
---- binutils.orig/gas/dwarf2dbg.c 2021-08-09 17:28:17.743318315 +0100
-+++ binutils-2.37/gas/dwarf2dbg.c 2021-08-09 17:28:27.043264112 +0100
-@@ -620,7 +620,22 @@ get_directory_table_entry (const char *d
- if (can_use_zero)
- {
- if (dirs == NULL || dirs[0] == NULL)
-- d = 0;
-+ {
-+ const char * pwd = getpwd ();
-+
-+ if (dwarf_level >= 5 && strcmp (dirname, pwd) != 0)
-+ {
-+ /* In DWARF-5 the 0 entry in the directory table is expected to be
-+ the same as the DW_AT_comp_dir (which is set to the current build
-+ directory). Since we are about to create a directory entry that
-+ is not the same, allocate the current directory first.
-+ FIXME: Alternatively we could generate an error message here. */
-+ (void) get_directory_table_entry (pwd, strlen (pwd), true);
-+ d = 1;
-+ }
-+ else
-+ d = 0;
-+ }
- }
- else if (d == 0)
- d = 1;
-@@ -628,8 +643,8 @@ get_directory_table_entry (const char *d
- if (d >= dirs_allocated)
- {
- unsigned int old = dirs_allocated;
--
-- dirs_allocated = d + 32;
-+#define DIR_TABLE_INCREMENT 32
-+ dirs_allocated = d + DIR_TABLE_INCREMENT;
- dirs = XRESIZEVEC (char *, dirs, dirs_allocated);
- memset (dirs + old, 0, (dirs_allocated - old) * sizeof (char *));
- }
-@@ -779,7 +794,7 @@ allocate_filename_to_slot (const char *d
- {
- if (dirs == NULL)
- {
-- dirs_allocated = files[num].dir + 32;
-+ dirs_allocated = files[num].dir + DIR_TABLE_INCREMENT;
- dirs = XCNEWVEC (char *, dirs_allocated);
- }
-
-@@ -807,7 +822,7 @@ allocate_filename_to_slot (const char *d
- {
- if (dirs == NULL)
- {
-- dirs_allocated = files[num].dir + 32;
-+ dirs_allocated = files[num].dir + DIR_TABLE_INCREMENT;
- dirs = XCNEWVEC (char *, dirs_allocated);
- }
-
-@@ -840,7 +855,7 @@ allocate_filename_to_slot (const char *d
- dirlen = strlen (dirname);
- file = filename;
- }
--
-+
- d = get_directory_table_entry (dirname, dirlen, num == 0);
- i = num;
-
-@@ -2082,7 +2097,12 @@ out_dir_and_file_list (segT line_seg, in
- Otherwise use pwd as main file directory. */
- if (dirs_in_use > 0 && dirs != NULL && dirs[0] != NULL)
- dir = remap_debug_filename (dirs[0]);
-- else if (dirs_in_use > 1 && dirs != NULL && dirs[1] != NULL)
-+ else if (dirs_in_use > 1
-+ && dirs != NULL
-+ && dirs[1] != NULL
-+ /* DWARF-5 directory tables expect dir[0] to be the same as
-+ DW_AT_comp_dir, which is the same as pwd. */
-+ && dwarf_level < 5)
- dir = remap_debug_filename (dirs[1]);
- else
- dir = remap_debug_filename (getpwd ());
-@@ -2185,8 +2205,8 @@ out_dir_and_file_list (segT line_seg, in
- uses slot zero, but that is only set explicitly using a
- .file 0 directive. If that isn't used, but file 1 is,
- then use that as main file name. */
-- if (DWARF2_LINE_VERSION >= 5 && i == 0 && files_in_use >= 1)
-- files[0].filename = files[1].filename;
-+ if (DWARF2_LINE_VERSION >= 5 && i == 0 && files_in_use >= 1 && files[0].filename == NULL)
-+ files[0].filename = files[1].filename;
- else
- files[i].filename = "";
- if (DWARF2_LINE_VERSION < 5 || i != 0)
-Only in binutils-2.37/gas/testsuite/gas/elf: dwarf-5-dir0.d
-Only in binutils-2.37/gas/testsuite/gas/elf: dwarf-5-dir0.s
-diff -rup binutils.orig/gas/testsuite/gas/elf/dwarf-5-file0.d binutils-2.37/gas/testsuite/gas/elf/dwarf-5-file0.d
---- binutils.orig/gas/testsuite/gas/elf/dwarf-5-file0.d 2021-08-09 17:28:17.817317884 +0100
-+++ binutils-2.37/gas/testsuite/gas/elf/dwarf-5-file0.d 2021-08-09 17:28:27.043264112 +0100
-@@ -3,17 +3,18 @@
- #readelf: -wl
-
- #...
-- The Directory Table \(offset 0x.*, lines 3, columns 1\):
-+ The Directory Table \(offset 0x.*, lines 4, columns 1\):
- Entry Name
-- 0 \(indirect line string, offset: 0x.*\): master directory
-- 1 \(indirect line string, offset: 0x.*\): secondary directory
-- 2 \(indirect line string, offset: 0x.*\): /tmp
-+#...
-+ 1 \(indirect line string, offset: 0x.*\): master directory
-+ 2 \(indirect line string, offset: 0x.*\): secondary directory
-+ 3 \(indirect line string, offset: 0x.*\): /tmp
-
- The File Name Table \(offset 0x.*, lines 3, columns 3\):
- Entry Dir MD5 Name
-- 0 0 0x0 \(indirect line string, offset: 0x.*\): master source file
-- 1 1 0x0 \(indirect line string, offset: 0x.*\): secondary source file
-- 2 2 0x95828e8bc4f7404dbf7526fb7bd0f192 \(indirect line string, offset: 0x.*\): foo.c
-+ 0 1 0x0 \(indirect line string, offset: 0x.*\): master source file
-+ 1 2 0x0 \(indirect line string, offset: 0x.*\): secondary source file
-+ 2 3 0x95828e8bc4f7404dbf7526fb7bd0f192 \(indirect line string, offset: 0x.*\): foo.c
- #pass
-
-
-diff -rup binutils.orig/gas/testsuite/gas/elf/elf.exp binutils-2.37/gas/testsuite/gas/elf/elf.exp
---- binutils.orig/gas/testsuite/gas/elf/elf.exp 2021-08-09 17:28:17.817317884 +0100
-+++ binutils-2.37/gas/testsuite/gas/elf/elf.exp 2021-08-09 17:28:27.044264106 +0100
-@@ -297,6 +297,7 @@ if { [is_elf_format] } then {
- run_dump_test "dwarf2-19" $dump_opts
- run_dump_test "dwarf2-20" $dump_opts
- run_dump_test "dwarf-5-file0" $dump_opts
-+ run_dump_test "dwarf-5-dir0" $dump_opts
- run_dump_test "dwarf-4-cu" $dump_opts
- run_dump_test "dwarf-5-cu" $dump_opts
- run_dump_test "dwarf-5-nop-for-line-table" $dump_opts
-diff -rup binutils.orig/gas/testsuite/gas/i386/dwarf5-line-1.d binutils-2.37/gas/testsuite/gas/i386/dwarf5-line-1.d
---- binutils.orig/gas/testsuite/gas/i386/dwarf5-line-1.d 2021-08-09 17:28:17.782318088 +0100
-+++ binutils-2.37/gas/testsuite/gas/i386/dwarf5-line-1.d 2021-08-09 17:28:27.044264106 +0100
-@@ -33,7 +33,7 @@ Raw dump of debug contents of section \.
-
- The Directory Table \(offset 0x.*, lines 2, columns 1\):
- Entry Name
-- 0 \(indirect line string, offset: 0x.*\): .*/gas/testsuite/gas/i386
-+ 0 \(indirect line string, offset: 0x.*\): .*/gas/testsuite
- 1 \(indirect line string, offset: 0x.*\): .*/gas/testsuite/gas/i386
-
- The File Name Table \(offset 0x.*, lines 2, columns 3\):
-diff -rup binutils.orig/gas/testsuite/gas/i386/dwarf5-line-2.d binutils-2.37/gas/testsuite/gas/i386/dwarf5-line-2.d
---- binutils.orig/gas/testsuite/gas/i386/dwarf5-line-2.d 2021-08-09 17:28:17.785318070 +0100
-+++ binutils-2.37/gas/testsuite/gas/i386/dwarf5-line-2.d 2021-08-09 17:28:27.044264106 +0100
-@@ -33,7 +33,7 @@ Raw dump of debug contents of section \.
-
- The Directory Table \(offset 0x.*, lines 2, columns 1\):
- Entry Name
-- 0 \(indirect line string, offset: 0x.*\): .*/gas/testsuite/gas/i386
-+ 0 \(indirect line string, offset: 0x.*\): .*/gas/testsuite
- 1 \(indirect line string, offset: 0x.*\): .*/gas/testsuite/gas/i386
-
- The File Name Table \(offset 0x.*, lines 1, columns 3\):
---- /dev/null 2021-08-09 07:51:33.817495606 +0100
-+++ binutils-2.37/gas/testsuite/gas/elf/dwarf-5-dir0.s 2021-08-09 17:28:54.787102415 +0100
-@@ -0,0 +1,19 @@
-+ .section .debug_info,"",%progbits
-+ .4byte 0x8a
-+ .2byte 0x2
-+ .4byte .Ldebug_abbrev0
-+ .byte 0x4
-+ .uleb128 0x1
-+
-+ .file 0 "../not-the-build-directory/master-source-file.c"
-+ .line 1
-+ .text
-+ .octa 0x12345678901234567890123456789012
-+
-+ .file 1 "secondary directory/secondary source file"
-+ .line 2
-+ .word 2
-+
-+ .file 2 "/tmp" "foo.c" md5 0x95828e8bc4f7404dbf7526fb7bd0f192
-+ .line 5
-+ .word 6
---- /dev/null 2021-08-09 07:51:33.817495606 +0100
-+++ binutils-2.37/gas/testsuite/gas/elf/dwarf-5-dir0.d 2021-08-09 17:28:54.787102415 +0100
-@@ -0,0 +1,20 @@
-+#as: --gdwarf-5
-+#name: DWARF5 dir[0]
-+#readelf: -wl
-+
-+#...
-+ The Directory Table \(offset 0x.*, lines 4, columns 1\):
-+ Entry Name
-+ 0 \(indirect line string, offset: 0x0\): .*/gas/testsuite
-+ 1 \(indirect line string, offset: 0x.*\): ../not-the-build-directory
-+ 2 \(indirect line string, offset: 0x.*\): secondary directory
-+ 3 \(indirect line string, offset: 0x.*\): /tmp
-+
-+ The File Name Table \(offset 0x.*, lines 3, columns 3\):
-+ Entry Dir MD5 Name
-+ 0 1 0x0 \(indirect line string, offset: 0x.*\): master-source-file.c
-+ 1 2 0x0 \(indirect line string, offset: 0x.*\): secondary source file
-+ 2 3 0x95828e8bc4f7404dbf7526fb7bd0f192 \(indirect line string, offset: 0x.*\): foo.c
-+#pass
-+
-+